spring cloud-实现Eureka注册中心的HA

来源:互联网 发布:淘宝买家金钻好处 编辑:程序博客网 时间:2024/05/17 21:03

在前面的例子中,我们的Eureka Server都是单节点的,一旦该节点在生产中挂掉,就无法再提供服务的注册,为了保证注册中心的高可用,在生产中一般采用多节点的服务注册中心。

一、在hosts文件中加入如下配置

[java] view plain copy
  1. 127.0.0.1 peer1  
  2. 127.0.0.1 peer2  
二、修改application.yml配置文件
[java] view plain copy
  1. ---  
  2. spring:  
  3.   profiles: peer1                                 # 指定profile=peer1  
  4.   application:  
  5.     name: Eureka-Server1  
  6. server:  
  7.   port: 8761   # 注册服务的端口号  
  8. eureka:  
  9.   instance:  
  10.     hostname: peer1                               # 指定当profile=peer1时,主机名  
  11.   client:  
  12.     serviceUrl:  
  13.       defaultZone: http://peer2:8762/eureka/      # 将自己注册到peer2这个Eureka上面去  
  14.   
  15. ---  
  16. spring:  
  17.   profiles: peer2  
  18.   application:  
  19.     name: Eureka-Server2  
  20. server:  
  21.   port: 8762  
  22. eureka:  
  23.   instance:  
  24.     hostname: peer2  
  25.   client:  
  26.     serviceUrl:  
  27.       defaultZone: http://peer1:8761/eureka/  # 服务注册地址,将自己注册到peer2上去  
三、打jar包

在命令行输入如下命令:

[java] view plain copy
  1. mvn clean package  
四、执行jar
[java] view plain copy
  1. java -jar springcloud-eureka-ha-0.0.1-SNAPSHOT.jar --spring.profiles.active=peer1  
  2. 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不可用,原因如下:在注册的时候,配置文件中的

[java] view plain copy
  1. spring:  
  2.   application:  
  3.     name: Eureka-Server2  
必须一致,下面我们将两个Eureka Server中的name都改成Eureka-Server,结果如下:


六、将服务注册到双Eureka Server上

只需修改defaultZone即可

[java] view plain copy
  1. # Eureka Server注册服务的地址  
  2. eureka.client.service-url.defaultZone=http://peer1:8761/eureka/,http://peer2:8762/eureka  
七、高可用验证

1、在浏览器输入:http://localhost:7902/user/1

结果如下:

[java] view plain copy
  1. {"id":1,"username":"user1","name":"张三","age":20,"balance":100.00}  
说明服务可用

2、将Eureka Server2停掉,发现Server2不可用


3、再次在浏览器中输入:http://localhost:7902/user/1

发现服务有返回

[java] view plain copy
  1. {"id":1,"username":"user1","name":"张三","age":20,"balance":100.00}  
通过上面几个步骤,就可以实现Eureka的HA了,有些小坑要注意一下!
阅读全文
0 0
原创粉丝点击