前言
之前写了一篇《SpringCloud Eureka测试项目--一个最简单的订单获取功能》,描述了最简单的一个SpringCloud项目的结构,方便新手搭建SpringCloud+Eureka的项目。
本文想说说 Eureka 注册中心的集群配置。
原因
Eureka的结构分为 服务端和客户端。
Eureka服务端提供了服务注册中心的功能,即实现了服务的注册和发现。
但是,如果只有一个注册中心,一旦注册中心崩溃了,就满盘皆输了,所有的服务都无法使用了。
本文尝试通过Eureka注册中心集群的方式,解决这一问题。
Euraka Server端集群配置的思路
Euraka Server是一个注册中心,不仅仅Eureka客户端可以注册,Eureka服务端也可以注册在其上。
因此,可以启动多个Eurake Server端,互相注册,即可实现集群。
本文档中创建了三个Server端,互相注册。当然,在实际生成中,可以启动更多个注册中心,形成可用性更强的集群。
自定义 hostname 方式配置集群
这种方式在hosts 文件中设置 hostname ,如下:
127.0.0.1 eurekaServer1
127.0.0.1 eurekaServer2
127.0.0.1 eurekaServer3
创建3个 Eureka Server的 application.yml 文件 分别如下:
第一个的 application.yml :
# 端口
server:
port: 8761
spring:
application:
name: cloud-eureka-server
# Eureka配置
eureka:
instance:
# eureka服务端的实例名称
hostname: eurekaServer1
server:
enable-self-preservation: false
client:
# false表示不向注册中心注册自己
register-with-eureka: false
# false表示自己端就是注册中心,职责就是维护服务实例,并不需要去检查服务
fetch-registry: false
# 设置与Eureka Server交互的地址查询服务和注册服务都需要依赖这个地址
service-url:
defaultZone: http://eurekaServer2:8762/eureka,http://eurekaServer3:8763/eureka
第2个的 application.yml :
# 端口
server:
port: 8762
spring:
application:
name: cloud-eureka-server
# Eureka配置
eureka:
instance:
# eureka服务端的实例名称
hostname: eurekaServer2
server:
enable-self-preservation: false
client:
# false表示不向注册中心注册自己
register-with-eureka: false
# false表示自己端就是注册中心,职责就是维护服务实例,并不需要去检查服务
fetch-registry: false
# 设置与Eureka Server交互的地址查询服务和注册服务都需要依赖这个地址
service-url:
defaultZone: http://eurekaServer1:8761/eureka,http://eurekaServer3:8763/eureka
第3个的 application.yml :
# 端口
server:
port: 8763
spring:
application:
name: cloud-eureka-server
# Eureka配置
eureka:
instance:
# eureka服务端的实例名称
hostname: eurekaServer3
server:
enable-self-preservation: false
client:
# false表示不向注册中心注册自己
register-with-eureka: false
# false表示自己端就是注册中心,职责就是维护服务实例,并不需要去检查服务
fetch-registry: false
# 设置与Eureka Server交互的地址查询服务和注册服务都需要依赖这个地址
service-url:
defaultZone: http://eurekaServer1:8761/eureka,http://eurekaServer2:8762/eureka
最后 ,我们看看 Eureka 服务提供者的 application.yml 文件是如何的 。
server:
port: 8001
spring:
application:
name: provider-order
eureka:
# serverInstance:
# hostname: 127.0.0.1
client:
# 表示将自己注册进Eureka Server默认为true
register-with-eureka: true
# 是否从Eureka Server抓去已有的注册信息,默认是true
fetch-registry: true
# 设置与Eureka Server交互的地址查询服务和注册服务都需要依赖这个地址
service-url:
defaultZone: http://127.0.0.1:8761/eureka,http://127.0.0.1:8762/eureka,http://127.0.0.1:8763/eureka
配置后,在浏览器中查看 Eureka 的Server ,可以看到 DS Replicas 互相之间都是存在的。
下面是 eurekaServer1 的 页面截图:
同时,服务提供者在3个 Server中都注册成功。