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 互相之间都是存在的。

同时,服务提供者在3个 Server中都注册成功。

经验分享 程序员 微信小程序 职场和发展