業餘草 SpringCloud教程 | 第十篇: 高可用的服務註冊中心(Finchley版本)
前面第一篇文章:業餘草 SpringCloud 教程 | 第一篇: 服務的註冊與發現Eureka(Finchley版本)
介紹了服務註冊與發現,其中服務註冊中心Eureka Server,是一個例項,當成千上萬個服務向它註冊的時候,它的負載是非常高的,這在生產環境上是不太合適的,這篇文章主要介紹怎麼將Eureka Server叢集化。
一、準備工作
Eureka can be made even more resilient and available by running multiple instances and asking them to register with each other. In fact, this is the default behaviour, so all you need to do to make it work is add a valid serviceUrl to a peer, e.g.
摘自官網
Eureka通過執行多個例項,使其更具有高可用性。事實上,這是它預設的熟性,你需要做的就是給對等的例項一個合法的關聯serviceurl。
這篇文章我們基於第一篇文章的工程,來做修改。
二、改造工作
在eureka-server工程中resources資料夾下,建立配置檔案application-peer1.yml:
server:
port: 8761
spring:
profiles: peer1
eureka:
instance:
hostname: peer1
client:
serviceUrl:
defaultZone: http://peer2:8769/eureka/
並且建立另外一個配置檔案application-peer2.yml:
server:
port: 8769
spring:
profiles: peer2
eureka:
instance:
hostname: peer2
client:
serviceUrl:
defaultZone: http://peer1:8761/eureka/
這時eureka-server就已經改造完畢。
ou could use this configuration to test the peer awareness on a single host (there’s not much value in doing that in production) by manipulating /etc/hosts to resolve the host names.
按照官方文件的指示,需要改變etc/hosts,linux系統通過vim /etc/hosts ,加上:
127.0.0.1 peer1
127.0.0.1 peer2
windows電腦,在c:/windows/systems/drivers/etc/hosts 修改。
這時需要改造下service-hi:
eureka:
client:
serviceUrl:
defaultZone: http://peer1:8761/eureka/
server:
port: 8762
spring:
application:
name: service-hi
三、啟動工程
啟動eureka-server:
java -jar eureka-server-0.0.1-SNAPSHOT.jar - -spring.profiles.active=peer1
java -jar eureka-server-0.0.1-SNAPSHOT.jar - -spring.profiles.active=peer2
啟動service-hi:
java -jar service-hi-0.0.1-SNAPSHOT.jar
訪問:localhost:8761,如圖:
你會發現註冊了service-hi,並且有個peer2節點,同理訪問localhost:8769你會發現有個peer1節點。
client只向8761註冊,但是你開啟8769,你也會發現,8769也有 client的註冊資訊。
個人感受:這是通過看官方文件的寫的demo ,但是需要手動改host是不是不符合Spring Cloud 的高上大?
Prefer IP Address
In some cases, it is preferable for Eureka to advertise the IP Adresses of services rather than the hostname. Set eureka.instance.preferIpAddress to true and when the application registers with eureka, it will use its IP Address rather than its hostname.
摘自官網
eureka.instance.preferIpAddress=true是通過設定ip讓eureka讓其他服務註冊它。也許能通過去改變去通過改變host的方式。
此時的架構圖:
Eureka-eserver peer1 8761,Eureka-eserver peer2 8769相互感應,當有服務註冊時,兩個Eureka-eserver是對等的,它們都存有相同的資訊,這就是通過伺服器的冗餘來增加可靠性,當有一臺伺服器當機了,服務並不會終止,因為另一臺服務存有相同的資料。
本文原始碼下載:
https://github.com/forezp/SpringCloudLearning/tree/master/sc-f-chapter10
四、參考文獻
感謝您的關注!可加QQ1群:135430763,QQ2群:454796847,QQ3群:187424846。QQ群進群密碼:xttblog,想加微信群的朋友,可以微信搜尋:xmtxtt,備註:“xttblog”,新增助理微信拉你進群。備註錯誤不會同意好友申請。再次感謝您的關注!後續有精彩內容會第一時間發給您!原創文章投稿請傳送至532009913@qq.com郵箱。商務合作可新增助理微信進行溝通!
相關文章
- SpringCloud分散式微服務雲架構 第十篇: 高可用的服務註冊中心(Finchley版本)SpringGCCloud分散式微服務架構
- 業餘草 SpringCloud 教程 | 第一篇: 服務的註冊與發現Eureka(Finchley版本)SpringGCCloud
- 業餘草 SpringCloud教程 | 第七篇: 高可用的分散式配置中心(Spring Cloud Config)(Finchley版本)SpringGCCloud分散式
- 業餘草 SpringCloud教程 | 第三篇: 服務消費者(Feign)(Finchley版本)SpringGCCloud
- 業餘草 SpringCloud教程 | 第二篇: 服務消費者(rest+ribbon)(Finchley版本)SpringGCCloudREST
- 業餘草 SpringCloud教程 | 第六篇: 分散式配置中心(Spring Cloud Config)(Finchley版本)SpringGCCloud分散式
- 業餘草 SpringCloud教程 | 第九篇: 服務鏈路追蹤(Spring Cloud Sleuth)(Finchley版本)SpringGCCloud
- 業餘草 SpringCloud教程 | 第四篇:斷路器(Hystrix)(Finchley版本)SpringGCCloud
- 業餘草 SpringCloud教程 | 第五篇: 路由閘道器(zuul)(Finchley版本)SpringGCCloud路由Zuul
- 業餘草 SpringCloud教程 | 第十一篇: 斷路器監控(Hystrix Dashboard)(Finchley版本)SpringGCCloud
- 業餘草 SpringCloud教程 | 第八篇: 訊息匯流排(Spring Cloud Bus)(Finchley版本)SpringGCCloud
- 業餘草 SpringCloud教程 | 第十二篇: 斷路器聚合監控(Hystrix Turbine)(Finchley版本)SpringGCCloud
- [SpringCloud教程]3. Eureka服務註冊中心整合SpringGCCloud
- SpringCloud實踐(三) 高可用的Eureka註冊中心SpringGCCloud
- SpringCloud註冊中心高可用搭建SpringGCCloud
- SpringCloud-Alibaba之Nacos服務註冊中心SpringGCCloud
- 轉載:史上最簡單的 SpringCloud 教程 | 第一篇: 服務的註冊與發現Eureka(Finchley版本)SpringGCCloud
- Spring Cloud:使用Eureka叢集搭建高可用服務註冊中心SpringCloud
- Spring Cloud Eureka 實現高可用服務發現註冊中心SpringCloud
- 【SpringCloud】consul註冊中心註冊的服務為內網(區域網)IPSpringGCCloud內網
- SpringCloud分散式微服務雲架構 第一篇: 服務的註冊與發現Eureka(Finchley版本)SpringGCCloud分散式微服務架構
- SpringCloud之服務註冊SpringGCCloud
- java B2B2C Springcloud多租戶電子商城系統-高可用的服務註冊中心JavaSpringGCCloud
- SpringCloud學習系列之一 ----- 搭建一個高可用的註冊中心(Eureka)SpringGCCloud
- SpringCloud——Eureka-微服務的註冊中心SpringGCCloud微服務
- 《springcloud 一》搭建註冊中心,服務提供者,服務消費者SpringGCCloud
- consul 服務註冊中心
- 【SpringBoot】服務對註冊中心的註冊時機Spring Boot
- SpringCloud微服務雲架構構建B2B2C電子商務平臺之-(十)高可用的服務註冊中心SpringGCCloud微服務架構
- Spring Cloud 系列(二)Eureka 高可用註冊中心SpringCloud
- lms框架服務註冊中心框架
- SpringCloud 教程 | 第一篇: 服務的註冊與發現(Eureka)(2.X版本)SpringGCCloud
- (十)Java B2B2C o2o多使用者商城 springcloud架構 高可用的服務註冊中心JavaSpringGCCloud架構
- SpringCloud整合Consul註冊中心SpringGCCloud
- springcloud(二):註冊中心EurekaSpringGCCloud
- SpringCloud服務的註冊與發現(Eureka)SpringGCCloud
- springcloud-註冊中心和配置中心SpringGCCloud
- spring cloud構建網際網路分散式微服務雲平臺-高可用的服務註冊中心SpringCloud分散式微服務