springcloud超簡單的入門2--Eureka服務治理

来源:https://www.cnblogs.com/justalittlecoder/archive/2019/09/14/11519922.html
-Advertisement-
Play Games

Eureka服務治理 下麵請聽第一個話題,母。。。咳咳,拿錯書了。 Eureka簡介 eureka是什麼呢? 簡單來說呢,當我的微服務應用多了起來,一個一個寫死再程式里是件很不優雅的事情,而且同一服務可能會多個實例存在,來對服務分流,就是負載均衡。 所以,我們需要一個位置來存放服務的訪問列表,以供消 ...


Eureka服務治理

下麵請聽第一個話題,母。。。咳咳,拿錯書了。

Eureka簡介

eureka是什麼呢?

簡單來說呢,當我的微服務應用多了起來,一個一個寫死再程式里是件很不優雅的事情,而且同一服務可能會多個實例存在,來對服務分流,就是負載均衡。

所以,我們需要一個位置來存放服務的訪問列表,以供消費端來使用,這個東西呢,就可以用eureka來實現。

我們來看一下eureka的相關概念:

  • ​ 相關概念

    • 服務註冊(Register)

      eureka客戶端向Eureka伺服器註冊時,它提供自身的元數據,比如IP地址,埠信息

    • 服務續約(Renew)

      客戶端每隔30秒發送一次心跳來進行服務續約。

    • 服務下線(Cancel)

      客戶端在程式關閉時向伺服器發送取消請求,成功該實例將會從伺服器註冊列表中刪除

    • 服務剔除(Eviction)

      預設情況下,當客戶端連續90秒沒有發送心跳請求,伺服器就會將該服務實例從服務列表中刪除,剔除該服務

    • 獲取服務註冊列表信息(Fetch Registriers)

      客戶端從伺服器獲取服務註冊列表信息,並將其緩存在本地。列表信息定期(30秒)更新一次。

不太理解也沒關係,我們可以先把架子搭建起來,之後慢慢悟把。

Eureka角色

Eureka中存在三種角色,註冊中心,服務提供者,服務消費者。

其中註冊中心是Eureka服務端,服務提供者與服務消費者都是客戶端。

  • 註冊中心伺服器

    主要進行,服務註冊,服務續約和服務下線。就是維護服務列表的東東啦。

    讓我們一步一步的開始把

    • 相關依賴
    <dependency>
          <groupId>org.springframework.cloud</groupId>
          <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
    </dependency>
    • 啟動類配置,使用@EnableEurekaServer註解,啟用Eureka服務
    @SpringBootApplication
    @EnableEurekaServer
    public class EurekacenteralApplication {
        public static void main(String[] args) {
            SpringApplication.run(EurekacenteralApplication.class, args);
        }
    
    }
    • 屬性配置
    server:
      port: 9090 ##UI界面埠
    eureka:
      instance:
        hostname: localhost  ##主機名稱
      client:
        register-with-eureka: false  ##是否註冊到服務中心,因為本身就是服務中心,不需要註冊
        fetch-registry: false  ##是否發現服務
        service-url:          ##註冊中心服務地址
          defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

    啟動服務,這樣一個簡單的註冊中心就啟動起來,瀏覽器訪問http://localhost:9090 就可以看到eureka的監控界面了。

  • 服務提供者

    eureka客戶端,向外提供服務

    • 相關依賴,作為Euraka客戶端
     <dependency>
         <groupId>org.springframework.cloud</groupId>
         <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
     </dependency>
    • 啟動類配置,使用@EnableEurekaClient註解,啟動Eureka客戶端
    @SpringBootApplication
    @EnableEurekaClient
    public class App {
        public static void main(String[] args) {
            SpringApplication.run(App.class,args);
        }
    }
    • 屬性配置(單機時可以通過設置不同埠,來啟動多個服務)
    server:
      port: 8080
    eureka:
      instance:
        prefer-ip-address: true  ##使用IP註冊服務
      client:
        register-with-eureka: true  #預設就是true,可以不用設置
        fetch-registry: true  #預設是true,可以不用設置
        service-url:
          defaultZone: http://localhost:9090/eureka/
    spring:
      application:
        name: microservice-provider
    • 服務介面
    @RestController
    @RequestMapping("/")
    public class TestController {
    
        @GetMapping("hi/{name}")
        public String hi(@PathVariable String name, HttpServletRequest request){
    
            return "hi,welcome "+name+" from port:"+request.getServerPort();
        }
    }
  • 服務消費者

    本質上與提供者為同一類客戶端,會在本地緩存一份服務列表信息,會定期更新緩存

    • 相關依賴
    <dependency>
         <groupId>org.springframework.cloud</groupId>
         <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>
    • 啟動類配置
    @SpringBootApplication
    public class App {
    
        public static void main(String[] args) {
            SpringApplication.run(App.class,args);
        }
        @Bean
        public RestTemplate getRestTemplate(){
            return new RestTemplate();
        }
    }
    • 屬性配置
    server:
      port: 8090
    eureka:
      client:
        service-url:
          defaultZone: http://localhost:9090/eureka/
        register-with-eureka: false ##僅僅作為消費者
        fetch-registry: true  #預設是true,可以不用設置
    
      ## 多說幾句,服務者跟消費者不是絕對的,他們可以同時作為兩種角色存在
      ## register-with-eureka: true
      ## fetch-registry: true  
      ## 當這兩個熟悉都為true的時候,就可以作為兩種角色同時存在了,即可以作為提供者,向外提供服務
      ## 又可以作為消費者,消費服務
    • 服務消費,都在代碼里,我幹了,你隨意。
    @RestController
    @RequestMapping("/")
    public class TestController {
    
    
        // 服務只有一個實例運行的時候,一個服務提供者,
        // 就算不註冊到eureka,我們也可以使用這種方式就行調用
        @Resource
        RestTemplate restTemplate;
        @GetMapping("hi")
        public String hi() {
            return restTemplate.getForObject("http://localhost:8090/hi/consumer", String.class);
        }
    
        //當服務有多個實例的時候,我們就可以使用服務發現或獲取服務列表,並取其中一個實例進行調用
        // 這樣才是實際場景,當然還用更簡潔的使用方式,我們下次說
        @Resource
        DiscoveryClient discoveryClient;
        //通過服務發現,獲取註冊中心上註冊的服務,獲取調用地址,然後調用服務
        @GetMapping("hi2")
        public String hi2() {
            List<ServiceInstance> serviceInstances = discoveryClient
                    .getInstances("microservice-provider");
            if (serviceInstances.size() == 0) return "service has down";
            // 這裡就是取第一個服務來消費
            return restTemplate.getForObject(String.format("%s/hi/consumer", serviceInstances.get(0).getUri()),
                    String.class);
        }
    }

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、起因 從《大型網站架構系列》到《架構師入門實踐》,一直想把代碼設計和架構的知識進行總結,但是苦於精力和能力有限,推動起來比較緩慢。也多次收到出版社的邀請,但遲遲沒有動筆。偶爾也會糾結做視頻還是寫文章,考慮到業餘寫作和工作之間的平衡,還是先以文章為主吧。寫出來和大家交流,算是自己的一個知識總結,如 ...
  • MVC模式 在講解Servlet前,先介紹一下MVC模式。 M:model 模型,相當於數據層,用於存放數據,如一個Java中的一個bean類 V:view 視圖,相當於頁面層,用於顯示數據,如一個網頁html,或者是jsp C: controller 控制器,相當於業務層,用於處理數據 我們之前使 ...
  • 一:基礎演算法題5道 1.阿姆斯特朗數 如果一個n位正整數等於其各位數字的n次方之和,則稱該數為阿姆斯特朗數。判斷用戶輸入的數字是否為阿姆斯特朗數。 (1)題目分析:這裡要先得到該數是多少位的,然後再把每一位的數字截取出來,把各位數字的n次方之和和該數一起判斷即可。(2)演算法分析:python中有le ...
  • [TOC] 序言:上一章我們初步介紹了一下Docker的概念,那麼這次我們著手於Docker的使用,瞭解一下常見的Docker的操作命令。此外不管學習什麼東西,我們不但要瞭解縱向的知識體系,最好能加上橫向的擴展,進行類比,Docker的命令風格和Git有著種種相似。好了廢話不多說,我們開始Docke ...
  • 按照上邊的執行流程圖,我們可以看出一個SpringMVC整體的一個執行輪廓,下麵我們具體來分析下 首先伺服器接收到一個請求,匹配並調用了我們的前端控制器(DispatcherServlet)也叫中央處理器的請求路徑,在web.xml文件中配置,我們來看下配置文件 因為DispatcherServle ...
  • [TOC] 1. 引用的定義 C++新增加了引用的概念: 引用可以看作一個已定義變數的別名 引用的語法 2. 引用的本質 引用在C++中的內部實現是一個常量指針 C++編譯器在編譯過程中使用常量指針作為引用的內部實現,因此引用所占用的記憶體大小和指針相同 從使用的角度,引用只是一個別名,C++為了實用 ...
  • 效果如下: 實現代碼; ...
  • [TOC] 題目 "P3958 乳酪" 思路 並查集。將乳酪的下錶面設為$0$號,輸入空洞位置時判斷該空洞如果與下錶面相切或相交就和到一個集合里,最後找到與上錶面相切或相交的空洞判斷與$0$號是否在一個集合里。 $Code$ ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...