Spring cloud ——EurekaServer

来源:https://www.cnblogs.com/wreading/archive/2019/11/12/11808690.html
-Advertisement-
Play Games

Eureka作為服務註冊與發現的組件,Eureka2.0已經閉源了,但是本教程還是以Eureka為核心進行展開。 1、三個模塊 Spring Cloud Eureka是Spring Cloud Netflix微服務套件之一,基於Netflix Eureka做了二次封裝,主要負責完成微服務架構中的服務 ...


      Eureka作為服務註冊與發現的組件,Eureka2.0已經閉源了,但是本教程還是以Eureka為核心進行展開。

1、三個模塊

       Spring Cloud Eureka是Spring Cloud Netflix微服務套件之一,基於Netflix Eureka做了二次封裝,主要負責完成微服務架構中的服務治理功能。

       eueka的3個重要模塊,eureka-server,service-provider,service-consumer
       eureka-server:服務端,提供服務註冊和發現;
       eureka-client-service-provider:服務端,服務提供者,通過http rest告知服務端註冊,更新,取消服務;
       eureka-client-service-consumer:客戶端,服務消費者,通過http rest從服務端獲取需要服務的地址列表,然後配合一些負載均衡策略(ribbon)來調用服務端服務。 

2、eureka-server

        Eureka Server 的服務註冊數據存儲層是雙層的 ConcurrentHashMap(線程安全高效的 Map 集合)。
        第一層的key=spring.application.name 也就是客戶端實例註冊的應用名;value 為嵌套的 ConcurrentHashMap。
        第二層的key=instanceId 也就是服務的唯一實例 ID,value 為 Lease 對象,Lease 對象存儲著這個實例的所有註冊信息,包括 ip 、埠、屬性等。
        申明語句如下:
        private final ConcurrentHashMap<String, Map<String, Lease<InstanceInfo>>> registry= new ConcurrentHashMap<String, Map<String, Lease<InstanceInfo>>>();

 

        服務註冊表沒有持久化到資料庫,我想應該是出於性能的考慮吧。畢竟,註冊表信息是需要定時獲取、更新的。

3、創建服務註冊中心——demo

3.1、引入依賴pom.xml

     <dependencies>
          <dependency>
               <groupId>org.springframework.boot</groupId>
               <artifactId>spring-boot-starter-web</artifactId>
         </dependency>
        <dependency>
              <groupId>org.springframework.cloud</groupId>
              <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>
        <dependency>
             <groupId>org.springframework.boot</groupId>
             <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
          </dependency>
     </dependencies>

3.2、eureka server啟動代碼        

       @SpringBootApplication
       @EnableEurekaServer
       public class EurekaServerApplication {

             public static void main(String[] args) {
                   SpringApplication.run(EurekaServerApplication.class, args);
            }
       }

       @EnableEurekaServer的主要作用是啟動EurekaServer運行環境和上下文。

3.3、application配置文件

       application配置文件可以是xml或yml結構,我比較喜歡xml結構,yml是縮進格式,我覺得比較容易寫錯。

        server.port=8080

        spring.application.name: eureka-server 

        #服務註冊中心實例的主機名
       eureka.instance.hostname: localhost

        #表示是否將自己註冊在EurekaServer上,預設為true。由於當前應用就是EurekaServer,所以置為false
        eureka.client.register-with-eureka: false

       #表示表示是否從EurekaServer獲取註冊信息,預設為true。單節點不需要同步其他的EurekaServer節點的數據


       eureka.client.fetch-registry: false       

       #設置Eureka的地址
       eureka.client.service-url.defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

3.4、查看eureka server

       訪問http://localhost:8080/地址。如圖上部分

        Environment: 環境,預設為test,生產環境建議改下,看著順眼
        Data center: 數據中心,生產環境建議改下
        Current time:當前的系統時間
        Uptime:已經運行了多少時間
        Lease expiration enabled:是否啟用租約過期 ,自我保護機制關閉時,該值預設是true, 自我保護機制開啟之後為false。
        Renews threshold: 每分鐘最少續約數,Eureka Server 期望每分鐘收到客戶端實例續約的總數。
        Renews (last min): 最後一分鐘的續約數量(不含當前,1分鐘更新一次),Eureka Server 最後 1 分鐘收到客戶端實例續約的總數。

        

        頁面下部分:

 

 

    total-avail-memory : 總共可用的記憶體
    environment : 環境名稱,預設test 
    num-of-cpus : CPU的個數
    current-memory-usage : 當前已經使用記憶體的百分比
    server-uptime : 服務啟動時間
    registered-replicas : 相鄰集群複製節點
   unavailable-replicas :不可用的集群複製節點,   

    available-replicas :可用的相鄰集群複製節點

    ipAddr:eureka服務端IP
    status:eureka服務端狀態

3.5、源代碼鏈接:https://files-cdn.cnblogs.com/files/wreading/eureka-server.rar


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

-Advertisement-
Play Games
更多相關文章
  • 新學習react 開始配置react跨域的時候 在網上查看到是在packjson.json裡面添加如下代碼: 1 "proxy": { 2 "/api": { 3 "target": "http://localhost:8080" 4 }, 5 } 但是啟動項目之後報錯: 後來在網上查找錯誤,發現r ...
  • 效果如下: 代碼如下(點擊可展開查看源碼): <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset= ...
  • Vue是一套用於構建用戶界面的漸進式框架。所謂漸進式即是指我們可以通過Vue構建從簡單到複雜的頁面應用,並且Vue.js壓縮文件只有33K,構建簡單的頁面不會顯得臃腫,同時Vue構建的複雜頁面也不會顯得簡陋。 Vue實現了DOM對象和數據的雙向綁定,你不用直接操作DOM,這項工作完全由Vue來完成,... ...
  • 前沿:參考ES6語法的async/await的處理機制 先上一段代碼 1 function getMoney(){ 2 var money=[100,200,300] 3 for( let i=0; i<money.length; i++){ 4 compute.exec().then(()=>{ ...
  • 閉包的實現原理和作用 1、閉包的概念:指有權訪問另一個函數作用域中的變數的函數,一般情況就是在一個函數中包含另一個函數。 2、閉包的作用:訪問函數內部變數、保持函數在環境中一直存在,不會被垃圾回收機制處理 因為函數內部聲明 的變數是局部的,只能在函數內部訪問到,但是函數外部的變數是對函數內部可見的, ...
  • 讀取數據://ajax去伺服器端校驗$.ajax({ type:"post", url:"http://", data:{deviceid:1}, dataType:'json', success : function(data) { var jsonText = data; var ab= eva ...
  • 通過日常的工作記錄NPM常用命令,不斷的學習,不斷總結,未完待續…… ...
  • 場景 Nginx入門簡介和反向代理、負載均衡、動靜分離理解: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/102790862 Ubuntu Server 16.04 LTS上怎樣安裝下載安裝Nginx並啟動: https://b ...
一周排行
    -Advertisement-
    Play Games
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...