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
    评论
Spring Cloud Eureka是一个用于构建分布式系统中的服务注册和发现的开源框架。它基于Netflix的Eureka,提供了服务注册、服务发现和负载均衡的功能。在您的描述中,您提到了一些关于Eureka Server和服务提供者的配置和代码片段。 首先,您在Eureka Server的父工程中没有做任何改动,而是在单例的Eureka Server项目基础上进行了修改。这个Eureka Server使用了集群模式,分别使用了9090和9091端口作为两个实例的端口号。在Eureka Server的子工程中,您修改了host和application.yml的配置,分别使用了EurekaServerA和EurekaServerB作为两个实例的主机名,并指定了它们之间的相互注册和发现的URL。 然后,您提到了一个服务提供者项目,它的配置中也使用了Eureka Server的实例主机名作为服务注册和发现的地址,并启用了对Eureka Client依赖的引入。 综上所述,使用Spring Cloud Eureka可以实现服务的注册和发现功能。您的配置和代码片段中展示了如何配置Eureka Server和服务提供者,让它们能够注册和发现彼此。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [SpringCloudEureka使用篇](https://blog.csdn.net/yuanshangshenghuo/article/details/106962926)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

小崔爱读书

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

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

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

打赏作者

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

抵扣说明:

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

余额充值