欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

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

时间:2021-02-28 14:51:46|栏目:JAVA代码|点击:

前言:

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

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

127.0.0.1 peer1 
127.0.0.1 peer2 

二、修改application.yml配置文件

--- 
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包

在命令行输入如下命令:

mvn clean package 

四、执行jar

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/

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

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

spring: 
 application: 
  name: Eureka-Server2 

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

六、将服务注册到双Eureka Server上

只需修改defaultZone即可

# 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了,有些小坑要注意一下!

上一篇:浅谈在Spring中如何使用数据源(DBCP、C3P0、JNDI)

栏    目:JAVA代码

下一篇:Java中死锁的原理实战分析

本文标题:spring cloud实现Eureka注册中心的HA的方法

本文地址:http://www.codeinn.net/misctech/71665.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有