spring cloud實現(xiàn)Eureka注冊中心的HA的方法
前言:
在前面的例子中,我們的Eureka Server都是單節(jié)點的,一旦該節(jié)點在生產(chǎn)中掛掉,就無法再提供服務(wù)的注冊,為了保證注冊中心的高可用,在生產(chǎn)中一般采用多節(jié)點的服務(wù)注冊中心。
一、在hosts文件中加入如下配置
127.0.0.1 peer1 127.0.0.1 peer2
二、修改application.yml配置文件
--- spring: profiles: peer1 # 指定profile=peer1 application: name: Eureka-Server1 server: port: 8761 # 注冊服務(wù)的端口號 eureka: instance: hostname: peer1 # 指定當(dāng)profile=peer1時,主機(jī)名 client: serviceUrl: defaultZone: http://peer2:8762/eureka/ # 將自己注冊到peer2這個Eureka上面去 --- spring: profiles: peer2 application: name: Eureka-Server2 server: port: 8762 eureka: instance: hostname: peer2 client: serviceUrl: defaultZone: http://peer1:8761/eureka/ # 服務(wù)注冊地址,將自己注冊到peer2上去
三、打jar包
在命令行輸入如下命令:
mvn clean package
四、執(zhí)行jar
java -jar springcloud-eureka-ha-0.0.1-SNAPSHOT.jar --spring.profiles.active=peer1 java -jar springcloud-eureka-ha-0.0.1-SNAPSHOT.jar --spring.profiles.active=peer2
五、訪問Eureka Server
在瀏覽器輸入:http://localhost:8761/

在瀏覽器輸入:http://localhost:8762/

發(fā)現(xiàn)有點問題:registered-replicas和unavailable-replicas中都存在Eureka Server,并且當(dāng)前的Eureka Server不可用,原因如下:在注冊的時候,配置文件中的
spring: application: name: Eureka-Server2
必須一致,下面我們將兩個Eureka Server中的name都改成Eureka-Server,結(jié)果如下:

六、將服務(wù)注冊到雙Eureka Server上
只需修改defaultZone即可
# Eureka Server注冊服務(wù)的地址 eureka.client.service-url.defaultZone=http://peer1:8761/eureka/,http://peer2:8762/eureka
七、高可用驗證
1、在瀏覽器輸入:http://localhost:7902/user/1
結(jié)果如下:
{"id":1,"username":"user1","name":"張三","age":20,"balance":100.00}
說明服務(wù)可用
2、將Eureka Server2停掉,發(fā)現(xiàn)Server2不可用
3、再次在瀏覽器中輸入:http://localhost:7902/user/1
{"id":1,"username":"user1","name":"張三","age":20,"balance":100.00}
通過上面幾個步驟,就可以實現(xiàn)Eureka的HA了,有些小坑要注意一下!
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java數(shù)據(jù)結(jié)構(gòu)常見幾大排序梳理
Java常見的排序算法有:直接插入排序、希爾排序、選擇排序、冒泡排序、歸并排序、快速排序、堆排序等。本文詳解介紹它們的實現(xiàn)以及圖解,需要的可以參考一下2022-03-03
SpringBoot權(quán)限認(rèn)證Sa-Token的使用總結(jié)
Sa-Token是一款輕量級Java權(quán)限認(rèn)證框架,適用于快速搭建權(quán)限系統(tǒng),它提供了豐富的功能,包括登錄認(rèn)證、權(quán)限驗證、角色驗證、Session會話管理等,并且具有良好的社區(qū)支持和文檔資源,下面重點給大家介紹SpringBoot權(quán)限認(rèn)證Sa-Token的使用,感興趣的朋友一起看看吧2025-02-02
Spring boot 使用JdbcTemplate訪問數(shù)據(jù)庫
SpringBoot 是為了簡化 Spring 應(yīng)用的創(chuàng)建、運行、調(diào)試、部署等一系列問題而誕生的產(chǎn)物。本文重點給大家介紹spring boot 使用JdbcTemplate訪問數(shù)據(jù)庫,需要的朋友可以參考下2018-05-05
在SpringBoot中使用YourKit進(jìn)行性能調(diào)優(yōu)的教程詳解
在應(yīng)用程序的開發(fā)過程中,性能調(diào)優(yōu)是一個重要的環(huán)節(jié),在SpringBoot應(yīng)用程序中,我們可以使用YourKit來進(jìn)行性能調(diào)優(yōu),YourKit是一款非常強(qiáng)大的Java性能調(diào)優(yōu)工具,在本文中,我們將介紹如何在 SpringBoot應(yīng)用程序中使用YourKit進(jìn)行性能調(diào)優(yōu)2023-06-06
Mybatis批量插入大量數(shù)據(jù)的最優(yōu)方式總結(jié)
批量插入功能是我們?nèi)粘9ぷ髦斜容^常見的業(yè)務(wù)功能之一,下面這篇文章主要給大家總結(jié)介紹了關(guān)于Mybatis批量插入大量數(shù)據(jù)的幾種最優(yōu)方式,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-03-03

