如何将单机版的Eureka服务改为集群版Eureka服务
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ù)的路由地址相連接
- springcloudDemo-Eureka-7002
- springcloudDemo-Eureka-7003
服務(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)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 第四范式入围Forrester Wave
- 下一篇: 杰尼亚签约第四范式 开启奢侈品行业智慧零