服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - spring cloud实现Eureka注册中心的HA的方法

spring cloud实现Eureka注册中心的HA的方法

2021-03-27 11:47牛奋lch Java教程

本篇文章主要介绍了spring cloud实现Eureka注册中心的HA的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

前言:

在前面的例子中,我们的eureka server都是单节点的,一旦该节点在生产中挂掉,就无法再提供服务的注册,为了保证注册中心的高可用,在生产中一般采用多节点的服务注册中心。

一、在hosts文件中加入如下配置

?
1
2
127.0.0.1 peer1
127.0.0.1 peer2

二、修改application.yml配置文件

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
---
spring:
 profiles: peer1                 # 指定profile=peer1
 application:
  name: eureka-server1
server:
 port: 8761  # 注册服务的端口号
eureka:
 instance:
  hostname: peer1                # 指定当profile=peer1时,主机名
 client:
  serviceurl:
   defaultzone: http://peer2:8762/eureka/   # 将自己注册到peer2这个eureka上面去
 
---
spring:
 profiles: peer2
 application:
  name: eureka-server2
server:
 port: 8762
eureka:
 instance:
  hostname: peer2
 client:
  serviceurl:
   defaultzone: http://peer1:8761/eureka/ # 服务注册地址,将自己注册到peer2上去

三、打jar包

在命令行输入如下命令:

?
1
mvn clean package

四、执行jar

?
1
2
java -jar springcloud-eureka-ha-0.0.1-snapshot.jar --spring.profiles.active=peer1
java -jar springcloud-eureka-ha-0.0.1-snapshot.jar --spring.profiles.active=peer2

五、访问eureka server

在浏览器输入:http://localhost:8761/

spring cloud实现Eureka注册中心的HA的方法

在浏览器输入:http://localhost:8762/

spring cloud实现Eureka注册中心的HA的方法

发现有点问题:registered-replicas和unavailable-replicas中都存在eureka server,并且当前的eureka server不可用,原因如下:在注册的时候,配置文件中的

?
1
2
3
spring:
 application:
  name: eureka-server2

必须一致,下面我们将两个eureka server中的name都改成eureka-server,结果如下:

spring cloud实现Eureka注册中心的HA的方法

六、将服务注册到双eureka server上

只需修改defaultzone即可

?
1
2
# eureka server注册服务的地址
eureka.client.service-url.defaultzone=http://peer1:8761/eureka/,http://peer2:8762/eureka

七、高可用验证

1、在浏览器输入:http://localhost:7902/user/1

结果如下:

{"id":1,"username":"user1","name":"张三","age":20,"balance":100.00} 

说明服务可用

2、将eureka server2停掉,发现server2不可用

3、再次在浏览器中输入:http://localhost:7902/user/1

{"id":1,"username":"user1","name":"张三","age":20,"balance":100.00} 

通过上面几个步骤,就可以实现eureka的ha了,有些小坑要注意一下!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:http://blog.csdn.net/liuchuanhong1/article/details/54895070

延伸 · 阅读

精彩推荐