Eureka 集群搭建

来源:https://www.cnblogs.com/lyx666/archive/2020/04/22/12749077.html
-Advertisement-
Play Games

為什麼要搭建註冊中心集群 以防出現單點故障 也就是唯一那個註冊中心出現故障 導致整個架構故障 互相註冊 相互守望 先要修改本機的hosts文件的主機映射 增加映射 C:\Windows\System32\drivers\etc\hosts 1.修改之前7001配置文件 2.修改之後 需要修改host ...


為什麼要搭建註冊中心集群 以防出現單點故障 也就是唯一那個註冊中心出現故障 導致整個架構故障

互相註冊 相互守望

先要修改本機的hosts文件的主機映射 增加映射 C:\Windows\System32\drivers\etc\hosts

1.修改之前7001配置文件

server:
  port: 7001
eureka:
  instance:
    hostname: localhost #服務端的實例名稱
  client:
    #false表示不向伺服器註冊自己
    register-with-eureka: false
    #false表示自己就是註冊中心 去維護服務實例 不需要去檢索服務
    fetch-register: false
    #設置與Enreka server交互的地址查詢服務和註冊服務都需要這個地址
    service-url:
      defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/

2.修改之後 需要修改hostname 這個就是剛剛修改的本機的hosts主機映射 還需要修改服務地址

server:
  port: 7001
eureka:
  instance:
    hostname: eureka7001.com #服務端的實例名稱 主機別名  修改
  client:
    #false表示不向伺服器註冊自己
    register-with-eureka: false
    #false表示自己就是註冊中心 去維護服務實例 不需要去檢索服務
    fetch-register: false
    #設置與Enreka server交互的地址 查詢服務和註冊服務都需要這個地址  修改
    service-url:
      defaultZone: http://eureka7002.com:7002/eureka/

3.創建另一個註冊中心7002 導入依賴不贅述了 7002的application.yml配置

server:
  port: 7002
eureka:
  instance:
    hostname: eureka7002.com #服務端的實例名稱  主機別名 
  client:
    #false表示不向伺服器註冊自己
    register-with-eureka: false
    #false表示自己就是註冊中心 去維護服務實例 不需要去檢索服務
    fetch-register: false
    #設置與Enreka server交互的地址查詢服務和註冊服務都需要這個地址
    service-url:
      defaultZone: http://eureka7001.com:7001/eureka/

4.啟動7001 7002 配置成功


5.修改微服務提供者的配置client 其實只是增加了一個服務請求地址 defaultZone: http://eureka7001.com:7001/eureka,http://eureka7002.com:7002/eureka 集群版

8888消費者模塊

server:
  port: 8888
spring:
  application:
    name: cloud-order-service

eureka:
  client:
    register-with-eureka: true #自己註冊到eureka 預設true
    #是否從eureka抓取已有的註冊信息 預設為true 單節點無所謂 集群必須為true 才能配合ribbon使用負載均衡
    fetch-registry: true
    service-url:
      #defaultZone: http://localhost:7001/eureka  #註冊中心地址
      defaultZone: http://eureka7001.com:7001/eureka,http://eureka7002.com:7002/eureka #集群版

支付模塊8001

server:
  port: 8001

spring:
  application:
    name: cloud-payment-service
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    url: jdbc:mysql://localhost:3306/db2019?characterEncoding=utf8&useSSL=false&serverTimezone=UTC&rewriteBatchedStatements=true
    username: root
    password: 1234

mybatis:
  mapper-locations: classpath:mapper/*.xml  #配置文件
  type-aliases-package: com.lyx.cloud.entities #所有entity別名所在包
eureka:
  client:
    register-with-eureka: true #自己註冊到eureka 預設true
    #是否從eureka抓取已有的註冊信息 預設為true 單節點無所謂 集群必須為true 才能配合ribbon使用負載均衡
    fetch-registry: true
    service-url:
     # defaultZone: http://localhost:7001/eureka  #註冊中心地址  單機版
     defaultZone: http://eureka7001.com:7001/eureka,http://eureka7002.com:7002/eureka #集群版

5.啟動8888-消費者模塊 8001-支付模塊服務提供 成功註冊


6.微服務提供者 集群搭建 再創建一個支付模塊8002

server:
  port: 8002

spring:
  application:
    name: cloud-payment-service
  datasource:
    type: com.alibaba.druid.pool.DruidDataSource
    url: jdbc:mysql://localhost:3306/db2019?characterEncoding=utf8&useSSL=false&serverTimezone=UTC&rewriteBatchedStatements=true
    username: root
    password: 1234

mybatis:
  mapper-locations: classpath:mapper/*.xml  #配置文件
  type-aliases-package: com.lyx.cloud.entities #所有entity別名所在包
eureka:
  client:
    register-with-eureka: true #自己註冊到eureka 預設true
    #是否從eureka抓取已有的註冊信息 預設為true 單節點無所謂 集群必須為true 才能配合ribbon使用負載均衡
    fetch-registry: true
    service-url:
     # defaultZone: http://localhost:7001/eureka  #註冊中心地址  單機版
     defaultZone: http://eureka7001.com:7001/eureka,http://eureka7002.com:7002/eureka #集群版

7.運行所有模塊 註冊成功


8.修改單機版的8888消費者的controller 讓它不指定從服務埠

controller

@RestController
@Slf4j
public class OrderController {
@Autowired
private RestTemplate restTemplate;

//private static  final  String BASE_URL="http://localhost:8001"; 修改前的埠
private static  final  String BASE_URL="http://CLOUD-PAYMENT-SERVICE";  修改後 變成在eureka註冊的服務實例名稱

@PostMapping("/comsumer/payment/create")
public CommonResult<PayMent> create(@RequestBody PayMent payMent){
    return restTemplate.postForObject(BASE_URL+"/payment/create",payMent,CommonResult.class);
}

@GetMapping("/comsumer/payment/get/{id}")
public CommonResult<PayMent> getPaymentByid(@PathVariable("id") Long id){
    return restTemplate.getForObject(BASE_URL+"/payment/get/"+id,CommonResult.class);
}

}

9.修改RestTemplate 配置 需要給它添加一個註解@LoadBalanced 賦予RestTemplate負載均衡能力 預設是輪詢

是因為註冊中心暴露了多個支付模塊的服務名稱CLOUD-PAYMENT-SERVICE 但是消費者模塊不知道選哪個

@Configuration
public class ApplicationContextConfig {

    @Bean
    @LoadBalanced
    public RestTemplate getRestTemplate(){
        return new RestTemplate();
    }
}

10.測試 所以消費者模塊只關註微服務名稱



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

-Advertisement-
Play Games
更多相關文章
  • 高度自適應第一種情況 1.高度不去設置,或者高度設置auto 內容撐開父元素的高度。2.內容撐開父元素的高度 -> 最小高度的設置 min-height3.浮動元素添加高度自適應 -> 添加浮動元素的父元素沒有高度,會出現高度塌陷 解決高度塌陷的方法 (1)給出現高度塌陷的元素添加:overflow ...
  • 使用 history.replaceState(null, "title","arg"); 例如: history.replaceState(null, "",'?category_id=0'+'&page='+pageIndex); ...
  • Vue.js 事件處理器 <template> <div id="app"> <button v-on:click="fn">click me</button> </div> </template> <script> var count=1; export default { name: 'App' ...
  • "視頻講解" 什麼是雲開發 這裡引用官方的一段描述: 雲開發(Tencent CloudBase,TCB)是雲端一體化的後端雲服務 ,採用 serverless 架構,免去了移動應用構建中繁瑣的伺服器搭建和運維。同時雲開發提供的靜態托管、命令行工具(CLI)、Flutter SDK 等能力極大的降低 ...
  • 消息隊列都應用到了哪些實際的應用場景中? 一、再談消息隊列的應用場景 1、非同步處理:例如簡訊通知、終端狀態推送、App推送、用戶註冊等 2、數據同部:業務數據推送同步 3、重試補償:記賬失敗重試 4、系統解耦:通訊上下行、終端異常監控、分散式事件中心 5、流量削峰:秒殺場景下的下單處理 6、發佈訂閱 ...
  • 二哥,我就是上次說你《教妹學Spring》看不懂的那個小白,沒想到你還特意寫了一篇入門級的 Java 基礎知識,這次真的看懂了,感覺好棒。請原諒我上次的唐突,二哥能夠照顧我們這些小白的學習進度,真的是良心了。 以上是讀者 KEL 在上一篇基礎知識文章發佈後特意給我發來的信息,說實話,看完後蠻感動的, ...
  • OOP的七大原則 OCP(Open Closed Principle),開放封閉原則 :軟體實體應該擴展開放、修改封閉。 實現:合理劃分構件,一種可變性不應當散落在代碼的很多角落裡,而應當被封裝到一個對象里;一種可變性不應當與另一個可變性混合在一起。 DIP(Dependency Inversion ...
  • 一、timer定時器 1.關於定時器的應用:每隔一段固定的時間執行一段代碼。 2.函數Timer().schedule(TimerTask timerTask,Date date,long proid) package code_class_file; import java.text.Simple ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...