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
  • 移動開發(一):使用.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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...