SpringBoot2.0 + SpringCloud Eureka搭建高可用注册中心(Eureka之三)
上一篇中提到用SpringBoot2.0+Eureka搭建服务注册中心和服务提供者,详情参考:
https://www.cnblogs.com/SysoCjs/p/10127448.html
现在讲一下SpringCloud+Eureka搭建高可用注册中心。在微服务架构的分布式环境中,必须充分考虑可能会发生的故障情况,所以生产环境必须对各个组件进行高可用部署,对于微服务也是一样,Eureka的服务治理设计中,所有的节点既是服务提供者,也是服务消费者,服务中心也不例外。
Eureka服务的高可用实际上就是向别的服务注册中心注册自己,形成一个各个注册中心相互注册的闭环链。下面是项目的搭建:
一、根据上面链接新建一个项目,除了application.properties之外,所有信息一样。
这时,我们将application.properties文件删掉,新建两个properties文件(有些人喜欢用yaml),分别命名为application-peer1.properties和application-peer2.properties。
①application-peer1.properties文件配置如下:
二、在IDEA中创建两个服务启动项,分别根据peer1和peer2文件来启动服务。
1、在点击run那里,选择edit configurations...,
2、选中刚才创建的项目,会看到只有App这个启动项(我的项目是已经新建了peer1和peer2),
- 选中App,去掉“Single Instance only”的勾,这样子才能创建多例,(新建的也要去掉勾)
- 点击“+”,填写自定义的Name,
- 选择“Main Class”,作为这个properties的启动类,这个项目只有一个启动类,所以都选App启动类,
- 填写Program argument:--spring.profiles.active=peer1(--spring.profiles.active=peer2),表示当前服务是根据哪个properties文件进行加载配置,有不少人是喜欢用cmd窗口打包启动的。
当新建好了peer1和peer2,依然要点一下run那里,这时会多出来刚才新建的名字为peer1和peer2的选择,那么现在可以依次选择,并启动peer1和peer2服务,当启动第一个服务时会报错,这没关系,当启动第二个时,就正常,然后回去重启第一个服务,就正常了。这是因为启动第一个服务时,它会向第二个服务请求注册,而第二个服务还没有启动,会有connect refuse。
这个时候可以访问一下Spring Eureka,输入127.0.0.1:1111
在peer1服务注册中心里有两个服务,peer2和它自己,registered-replicas那里也显示了向它注册的服务中心信息。
输入127.0.0.1:1112,得到类似的效果:
至此,SpringBoot2.0+Eureka搭建高可用注册中心已经成功。