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
四、执行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/

发现有点问题: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了,有些小坑要注意一下!

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 9
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值