前言:
在前面的例子中,我们的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了,有些小坑要注意一下!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍springcloud实现注册中心Eureka,包括了springcloud实现注册中心Eureka的使用技巧和注意事项,需要的朋友参考一下 Eureka是Netflix开源的一款提供服务注册和发现的产品,它提供了完整的Service Registry和Service Discovery实现。也是springcloud体系中最重要最核心的组件之一。 背景介绍 服务中心 服务中心又称注
我有一个Eureka服务器,我想在那里注册一个非常基本的SpringBoot服务。不幸的是,服务没有注册,尽管我试图跟踪所有的文章,我可以找到。 此外,当我检查DiscoveryClient的描述(得到autowired)时,我看到“Spring Cloud No-op DiscoveryClient”,它表明(根据noopDiscoveryClient.java源代码)没有找到Eureka客户机
本文向大家介绍springcloud干货之服务注册与发现(Eureka),包括了springcloud干货之服务注册与发现(Eureka)的使用技巧和注意事项,需要的朋友参考一下 使用Eureka实现服务治理 作用:实现服务治理(服务注册与发现) 简介:Spring Cloud Eureka是Spring Cloud Netflix项目下的服务治理模块。而Spring Cloud Netflix项
本文向大家介绍SpringCloud Eureka Provider及Consumer的实现,包括了SpringCloud Eureka Provider及Consumer的实现的使用技巧和注意事项,需要的朋友参考一下 Eureka-Provider 服务的提供者 新建一个服务提供者项目 1、导入pom文件 2、在启动类上加注解 上边那个@EnableDiscoverClient 注解加不加都行的
本文向大家介绍Spring-Cloud Eureka注册中心实现高可用搭建,包括了Spring-Cloud Eureka注册中心实现高可用搭建的使用技巧和注意事项,需要的朋友参考一下 前言: spring-cloud为基础的微服务架构,所有的微服务都需要注册到注册中心,如果这个注册中心阻塞或者崩了,那么整个系统都无法继续正常提供服务,所以,这里就需要对注册中心进行集群,换言之,高可用(HA) 前提
本文向大家介绍SpringCloud之服务注册与发现Spring Cloud Eureka实例代码,包括了SpringCloud之服务注册与发现Spring Cloud Eureka实例代码的使用技巧和注意事项,需要的朋友参考一下 一、Spring Cloud简介 Spring Cloud是一个基千SpringBoot实现的微服务架构开发 工具。它为微服务架构中涉及的 配置管理、服务治理、 断路器