SpringCloud Eureka 注册中心的集群配置

前言

之前写了一篇《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中都注册成功

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小崔爱读书

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值