SpringCloud之eureka註冊中心入門

来源:https://www.cnblogs.com/Lyn4ever/archive/2020/02/24/12359582.html
-Advertisement-
Play Games

eureka註冊中心 一、基本概念 SpringCloud封裝 了Netflix公司的eureka作為自己微服務的註冊中心。這個註冊中心和dubbo中的zookeeper很相似,簡單來說,只要你可以將你的”微服務“模塊註冊到註冊中心,就可以供其他服務調用,一般來說,只有provider會註冊到eur ...


eureka註冊中心

一、基本概念

SpringCloud封裝 了Netflix公司的eureka作為自己微服務的註冊中心。這個註冊中心和dubbo中的zookeeper很相似,簡單來說,只要你可以將你的”微服務“模塊註冊到註冊中心,就可以供其他服務調用,一般來說,只有provider會註冊到eureka,consumer也可以註冊,但是並不建議這麼做。

eureka的架構圖如下:

二、在SpringCloud項目中使用eureka

  • 要想使用SpringCloud的子模塊,一般分為兩步:
    1. 引入相關的maven依賴
    2. 然後在配置類上加上@EnableXXX註解

1. 創建一個新的Maven的Module項目,用來開啟eureka

​ 為了讓小伙伴們更好地學習,我將上一次的項目複製了一份(見Github項目代碼)

  • pom.xml中添加依賴
<dependency>
   <groupId>org.springframework.cloud</groupId>
    <!--這個是服務端的依賴-->
   <artifactId>spring-cloud-starter-eureka-server</artifactId>
</dependency>   
  • 創建啟動類,併在啟動類上加上@EnableEurekaServer註解
@SpringBootApplication
@EnableEurekaServer
public class EurekaRegistApp_7001 {
    public static void main(String[] args) {
        SpringApplication.run(EurekaRegistApp_7001.class,args);
    }
}
  • 添加application.yml配置文件如下:
server:
  port: 7001

eureka:
  instance:
    hostname: localhost #eureka服務端的實例名稱
  client:
    register-with-eureka: false     #false表示不向註冊中心註冊自己。
    fetch-registry: false     #false表示自己端就是註冊中心,我的職責就是維護服務實例,並不需要去檢索服務
    service-url:
#    這兩個變數就是上邊定義過的
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/       #設置與Eureka Server交互的地址查詢服務和註冊服務都需要依賴這個地址。
  • 然後啟動這個項目,就輸入訪問地址http://localhost:7001/,就可以查看eureka註冊中心了

當有服務註冊到這裡時,就會在上圖中出現。

2. 將服務提供者註冊進eureka

  • 將eureka的依賴加入到pom.xml中
 <dependency>
     <groupId>org.springframework.cloud</groupId>
     <artifactId>spring-cloud-starter-eureka</artifactId>
 </dependency>
  • 修改provider項目的application.yml
server:
  port: 8001

spring:
  application:
#  這個應用的名稱,用來註冊在註冊中心的名稱
    name: demo2-provider

eureka:
  client: #客戶端註冊進eureka服務列表內
    service-url:
#    這個地址是在eureka的application.yml中定義過的
      defaultZone: http://localhost:7001/eureka
  instance:
    instance-id: demo2-provider-8001
    prefer-ip-address: true     #訪問路徑可以顯示IP地址
  • 修改啟動類,加上@EnableEurekaClient註解,表明這是一個eureka的客戶端,用來向eureka註冊此服務
@EnableEurekaClient //本服務啟動後會自動註冊進eureka服務中
@SpringBootApplication
public class Demo1Provider {
    public static void main(String[] args) {
        SpringApplication.run(Demo1Provider.class, args);
    }
}
  • 然後重新啟動這個服務提供者項目,就會在註冊中心中看到這個服務

三、幾個小插曲

  • 如果你的eureka註冊中心出現如圖情況

請不要驚慌,這隻是eureka的自我保護意識。Eureka Server 在運行期間會去統計心跳失敗比例在 15 分鐘之內是否低於 85%,如果低於 85%,Eureka Server 會將這些實例保護起來,讓這些實例不會過期,但是在保護期內如果服務剛好這個服務提供者非正常下線了,此時服務消費者就會拿到一個無效的服務實例,此時會調用失敗,對於這個問題需要服務消費者端要有一些容錯機制,如重試,斷路器等。

我們在單機測試的時候很容易滿足心跳失敗比例在 15 分鐘之內低於 85%,這個時候就會觸發 Eureka 的保護機制,一旦開啟了保護機制,則服務註冊中心維護的服務實例就不是那麼準確了,此時我們可以使用eureka.server.enable-self-preservation=false來關閉保護機制,這樣可以確保註冊中心中不可用的實例被及時的剔除(不推薦)。

  • 如何搭建eureka集群

原理就是多創建幾個eureka項目,但是埠不同,然後在註冊的時候,將它們寫在一起(下期會說到)

本項目代碼地址


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

-Advertisement-
Play Games
更多相關文章
  • 一、CSS偽元素 CSS 偽元素用於向某些選擇器設置特殊效果。 偽元素的用法如下: selector:pseudo-element {property:value;} CSS 類也可以和偽元素搭配使用 selector.class:pseudo-element {property:value;} 二 ...
  • 參考 博客 1、 "中高級前端面試題(萬字長文)" 2、 "大前端弔打面試官系列" 資料 1、 "HTML 5 教程" 2、 "CSS3 教程" 3、 "JavaScript 教程" 收費小冊 "前端面試之道" 註:某大佬這本收費小冊乾貨很多,有些參考其中的問題,就不列答案了。 寫在前面的話 因為一 ...
  • RX.js變化 RxJS 6主要用於Angular應用程式,從Angular 6開始,它是一個強制依賴。 與RxJS版本5相比,RxJS 6(或更高版本)引入了兩個重要更改: 1. import的導入結構發生變化 // 以前: import { Observable } from 'rxjs/Obs ...
  • 一、Overview angular 入坑記錄的筆記第二篇,介紹組件中的相關概念,以及如何在 angular 中通過使用組件來完成系統功能的實現 對應官方文檔地址: "顯示數據" "模板語法" "用戶輸入" "組件之間的交互" "管道" "生命周期鉤子" 配套代碼地址: "angular pract ...
  • 簡介 WebSocket 使得客戶端和伺服器之間的數據交換變得更加簡單, 允許服務端主動向客戶端推送數據。 在 WebSocket API 中,瀏覽器和伺服器只需要完成一次握手,兩者之間就直接 可以創建持久性的連接,併進行雙向數據傳輸。 現在,很多網站為了實現 推送技術 ,所用的技術都是 Ajax ...
  • 現如今,新型冠狀病毒疫情牽動著每一個人的神經,每天起床後的第一件事就是打開疫情地圖,看看最新的疫情數據。如何防控對於普通居民來說,減少外出,註意衛生等都是有效措施,另外保持室內通風換氣也是至關重要的,無論是飛沫傳播還是流傳的氣溶膠傳播,環境密閉導致空氣渾濁,易造成病菌滋生,增加人體感染疾病的風險。勤... ...
  • 一、項目框架準備 1.1 新建maven空項目,併在pom中引入依賴 1 <parent> 2 <groupId>org.springframework.boot</groupId> 3 <artifactId>spring-boot-starter-parent</artifactId> 4 <v ...
  • 一、Set集合 1.HashSet底層實際上是一個HashMap,HashMap底層採用了哈希表數據結構。 2.哈希表又稱為散列表,哈希表底層是一個數組,這個數組中每一個元素是一個單向鏈表,每個單向鏈表都有一個獨一無二的hash值,代表數組的下標。在某個單向鏈表中的每一個節點上的hash值是相等的, ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...