前言:
在前面的例子中,我們的eureka server都是單節點的,一旦該節點在生產中掛掉,就無法再提供服務的注冊,為了保證注冊中心的高可用,在生產中一般采用多節點的服務注冊中心。
一、在hosts文件中加入如下配置
1
2
|
127.0 . 0.1 peer1 127.0 . 0.1 peer2 |
二、修改application.yml配置文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
--- spring: profiles: peer1 # 指定profile=peer1 application: name: eureka-server1 server: port: 8761 # 注冊服務的端口號 eureka: instance: hostname: peer1 # 指定當profile=peer1時,主機名 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/ # 服務注冊地址,將自己注冊到peer2上去 |
三、打jar包
在命令行輸入如下命令:
1
|
mvn clean package |
四、執行jar
1
2
|
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/
發現有點問題:registered-replicas和unavailable-replicas中都存在eureka server,并且當前的eureka server不可用,原因如下:在注冊的時候,配置文件中的
1
2
3
|
spring: application: name: eureka-server2 |
必須一致,下面我們將兩個eureka server中的name都改成eureka-server,結果如下:
六、將服務注冊到雙eureka server上
只需修改defaultzone即可
1
2
|
# eureka server注冊服務的地址 eureka.client.service-url.defaultzone=http: //peer1:8761/eureka/,http://peer2:8762/eureka |
七、高可用驗證
1、在瀏覽器輸入:http://localhost:7902/user/1
結果如下:
{"id":1,"username":"user1","name":"張三","age":20,"balance":100.00}
說明服務可用
2、將eureka server2停掉,發現server2不可用
3、再次在瀏覽器中輸入:http://localhost:7902/user/1
{"id":1,"username":"user1","name":"張三","age":20,"balance":100.00}
通過上面幾個步驟,就可以實現eureka的ha了,有些小坑要注意一下!
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。
原文鏈接:http://blog.csdn.net/liuchuanhong1/article/details/54895070