微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

spring cloud实现Eureka注册中心的HA的方法

本篇文章主要介绍了spring cloud实现Eureka注册中心的HA的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

前言:

在前面的例子中,我们的Eureka Server都是单节点的,一旦该节点在生产中挂掉,就无法再提供服务的注册,为了保证注册中心的高可用,在生产中一般采用多节点的服务注册中心。一、在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 # 注册服务的端口号 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包在命令行输入如下命令:mvn clean package四、执行jarjava -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不可用,原因如下:在注册的时候,配置文件中的spring: application: name: Eureka-Server2必须一致,下面我们将两个Eureka Server中的name都改成Eureka-Server,结果如下:

六、将服务注册到双Eureka Server上只需修改defaultZone即可# 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了,有些小坑要注意一下!以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐