日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 >

如何将单机版的Eureka服务改为集群版Eureka服务

發(fā)布時(shí)間:2025/3/12 48 豆豆
生活随笔 收集整理的這篇文章主要介紹了 如何将单机版的Eureka服务改为集群版Eureka服务 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

Eureka 集群原理

基本原理

上圖是來自eureka的官方架構(gòu)圖,這是基于集群配置的eureka;

  • 處于不同節(jié)點(diǎn)的eureka通過Replicate進(jìn)行數(shù)據(jù)同步
  • Application Service為服務(wù)提供者
  • Application Client為服務(wù)消費(fèi)者
  • Make Remote Call完成一次服務(wù)調(diào)用

服務(wù)啟動(dòng)后向Eureka注冊(cè),Eureka Server會(huì)將注冊(cè)信息向其他Eureka Server進(jìn)行同步,當(dāng)服務(wù)消費(fèi)者要調(diào)用服務(wù)提供者,則向服務(wù)注冊(cè)中心獲取服務(wù)提供者地址,然后會(huì)將服務(wù)提供者地址緩存在本地,下次再調(diào)用時(shí),則直接從本地緩存中取,完成一次調(diào)用。

當(dāng)服務(wù)注冊(cè)中心Eureka Server檢測到服務(wù)提供者因?yàn)殄礄C(jī)、網(wǎng)絡(luò)原因不可用時(shí),則在服務(wù)注冊(cè)中心將服務(wù)置為DOWN狀態(tài),并把當(dāng)前服務(wù)提供者狀態(tài)向訂閱者發(fā)布,訂閱過的服務(wù)消費(fèi)者更新本地緩存。

Eureka 單機(jī)版到集群的改造過程

新建 兩個(gè)Eureka模塊項(xiàng)目

新建模塊(springcloudDemo-Eureka-7002和 springcloudDemo-Eureka-7003),至于如何在父項(xiàng)目下新建模塊請(qǐng)參考Eclipse構(gòu)建Maven分包項(xiàng)目并構(gòu)建服務(wù)端


注: 截圖中對(duì)應(yīng)的Eureka 即三個(gè)Eureka服務(wù)構(gòu)成Eureka集群

復(fù)制 springcloudDemo-Eureka-7001 中的內(nèi)容

由于是學(xué)習(xí)SpringCloud Eureka 所以Eureka服務(wù)沒有太多操作,所以將之前的設(shè)置的單機(jī)版Eureka 內(nèi)容復(fù)制過來


下的內(nèi)容,分別拷貝到對(duì)應(yīng)的其他Eureka集群成員中
特別注意:請(qǐng)不要為了方便直接拷貝Eclipse中springcloudDemo-Eureka-7001中的內(nèi)容,直接到其他的項(xiàng)目中,這樣做是會(huì)報(bào)錯(cuò)的。。。 所以別偷懶!!!

修改新建的兩個(gè)模塊的啟動(dòng)類名稱

這個(gè)也可以不修改,沒有啥太大的影響

修改hosts中的映射

Windows 位置: C:\Windows\System32\drivers\etc

127.0.0.1 eureka7001.com 127.0.0.1 eureka7002.com 127.0.0.1 eureka7003.com

修改三個(gè)Eureka服務(wù)的配置文件

下面針對(duì)三個(gè)服務(wù)的配置文件進(jìn)行相應(yīng)的說明:

  • springcloudDemo-Eureka-7001
    需要和另外兩個(gè)服務(wù)的路由地址相連接
server: port: 7001eureka:instance:hostname: eureka7001.com #eureka服務(wù)端的實(shí)例名稱, C:\Windows\System32\drivers\etc 的hosts已經(jīng)加入映射client:register-with-eureka: false #false表示不向注冊(cè)中心注冊(cè)自己。fetch-registry: false #false表示自己端就是注冊(cè)中心,我的職責(zé)就是維護(hù)服務(wù)實(shí)例,并不需要去檢索服務(wù)service-url:#單機(jī)#defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/ #設(shè)置與Eureka Server交互的地址查詢服務(wù)和注冊(cè)服務(wù)都需要依賴這個(gè)地址。#集群defaultZone: http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/
  • springcloudDemo-Eureka-7002
server: port: 7002eureka:instance:hostname: eureka7002.com #eureka服務(wù)端的實(shí)例名稱, C:\Windows\System32\drivers\etc 的hosts已經(jīng)加入映射client:register-with-eureka: false #false表示不向注冊(cè)中心注冊(cè)自己。fetch-registry: false #false表示自己端就是注冊(cè)中心,我的職責(zé)就是維護(hù)服務(wù)實(shí)例,并不需要去檢索服務(wù)service-url:#單機(jī)#defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/ #設(shè)置與Eureka Server交互的地址查詢服務(wù)和注冊(cè)服務(wù)都需要依賴這個(gè)地址。#集群defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7003.com:7003/eureka/
  • springcloudDemo-Eureka-7003
server: port: 7003eureka:instance:hostname: eureka7003.com #eureka服務(wù)端的實(shí)例名稱, C:\Windows\System32\drivers\etc 的hosts已經(jīng)加入映射client:register-with-eureka: false #false表示不向注冊(cè)中心注冊(cè)自己。fetch-registry: false #false表示自己端就是注冊(cè)中心,我的職責(zé)就是維護(hù)服務(wù)實(shí)例,并不需要去檢索服務(wù)service-url:#單機(jī)#defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/ #設(shè)置與Eureka Server交互的地址查詢服務(wù)和注冊(cè)服務(wù)都需要依賴這個(gè)地址。#集群defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/

服務(wù)提供者將配置文件從單機(jī)版修改為集群

原理: 服務(wù)注冊(cè)的時(shí)候,從注冊(cè)到一臺(tái)修改為注冊(cè)到多臺(tái)

#單機(jī)版#defaultZone: http://localhost:7001/eurekadefaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/

測試

分別啟動(dòng)三個(gè)Eureka服務(wù),形成Eureka集群,之后在啟動(dòng)服務(wù)提供者

打開瀏覽器分別輸入:

  • http://eureka7001.com:7001/
  • http://eureka7002.com:7002/
  • http://eureka7003.com:7003/

    可以查看 服務(wù)8001,已經(jīng)注冊(cè)到三臺(tái)Eureka集群中,Eureka集群正常啟動(dòng)。
    注: 為什么 http://eureka7003.com:7003/ 界面會(huì)報(bào)錯(cuò),這是因?yàn)镋ureka 保護(hù)機(jī)制導(dǎo)致,并不影響。

至此,從上一篇單機(jī)版到集群Eureka的改造完成。 至于服務(wù)消費(fèi)者訪問,由于現(xiàn)在只有一個(gè)生產(chǎn)者,所以目前不是很明顯,之后會(huì)構(gòu)建服務(wù)生產(chǎn)者集群,然后在測試服務(wù)消費(fèi)者,這樣會(huì)比較好比較。

總結(jié)

以上是生活随笔為你收集整理的如何将单机版的Eureka服务改为集群版Eureka服务的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。