上一篇文章【Spring Cloud搭建註冊中心】成功搭建了一個Eureka Server服務註冊中心,不過相信細心的朋友都會發現,這個服務註冊中心是一個單節點服務註冊中心,萬一發生故障或者服務器宕機,那全部的服務可就不能使用了,這個在生產環境了是不容許的。html
Eureka Server其實設計早就考慮到了高可用性,Eureka Server能夠將本身做爲服務註冊到其餘服務註冊中心,這樣能夠互相註冊,以實現服務清單的同步,達到高可用的效果。java
——————————————————————————————————————————————————————spring
在咱們上一篇文章中,搭建的eureka-server-test項目中添加兩個配置文件,aplication-peer1.properties和aplication-peer2.properties,詳細配置文件內容以下:瀏覽器
#端口號 server.port=8081 spring.profiles=peer1 eureka.instance.hostname=peer1 #向註冊中心註冊服務 eureka.client.registerWithEureka=false # 檢索服務 eureka.client.fetchRegistry=false eureka.client.serviceUrl.defaultZone=http://peer2:8082/eureka/ #在Eureka服務器獲取不到集羣裏對等服務器上的實例時,須要等待的時間 server.waitTimeInMsWhenSyncEmpty=0 #自我保護模式 server.enableSelfPreservation=false
#端口號 server.port=8082 spring.profiles=peer2 eureka.instance.hostname=peer2 #向註冊中心註冊服務 eureka.client.registerWithEureka=false # 檢索服務 eureka.client.fetchRegistry=false eureka.client.serviceUrl.defaultZone=http://peer1:8081/eureka/ #在Eureka服務器獲取不到集羣裏對等服務器上的實例時,須要等待的時間 server.waitTimeInMsWhenSyncEmpty=0 #自我保護模式 server.enableSelfPreservation=false
在peer1配置文件中,serviceUrl指向peer2,而peer2配置文件中,serviceUrl指向peer1,這樣就作到了相互註冊。這裏還須要注意在本地測試的時候,咱們須要修改host文件(C:\Windows\System32\drivers\etc),添加如下內容:服務器
127.0.0.1 peer1 127.0.0.1 peer2
使用IDEA進行Maven Intall,【 IntelliJ IDEA 社區版 Maven Install 和Maven clean】 app
這裏咱們不使用IDEA進行項目啓動,而是直接經過命令來啓動。測試
java -jar eureka-server-test-0.0.1-SNAPSHOT.jar --spring.profiles.active=peer1 java -jar eureka-server-test-0.0.1-SNAPSHOT.jar --spring.profiles.active=peer2
啓動成功以後,在瀏覽器中進行訪問,這時候在8081的DS Replicas中能夠看到peer2節點,在8082的DS Replicas中能夠看到peer1節點,這樣咱們雙節點的服務註冊中心就搭建好了。fetch
依然是上一篇文章中建立的eureka-client-test項目,修改提供者的配置文件:spa
server.port=9081 spring.application.name=client-demo eureka.client.serviceUrl.defaultZone=http://peer1:8081/eureka/,http://peer2:8082/eureka/
此處兩個服務註冊中的地址都添加上,以","分隔。 .net
而後分別訪問http://localhost:8081/ 和 http://localhost:8082/ 能夠看到提供者已經註冊到兩個服務註冊中心了。
到這裏,一個高可用的服務註冊中心集羣就搭建完成了。
原文出處:https://www.cnblogs.com/clarezhou/p/11078759.html