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
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...