前言:
在前面的例子中,我们的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