springCloud Finchley 实战入门(基于springBoot 2.0.3)【三 Eureka-高可用服务注册中心】

简介: Eureka高可用注册中心Eureka Server的设计一开始就考虑到了高可用的问题,在eureka服务治理设计中,所有的节点即是是服务提供方,也是服务消费方。

Eureka高可用注册中心

Eureka Server的设计一开始就考虑到了高可用的问题,在eureka服务治理设计中,所有的节点即是是服务提供方,也是服务消费方。

在部署高可用注册中心前我们先需要准备一下,本地环境。因为我们实例是在单台电脑上的,所以需要模拟堕胎服务器,我们需要修改一下本机的host文件。
windows的host文件在C:\Windows\System32\drivers\etc\hosts
在host文件后面加上

127.0.0.1 peer1
127.0.0.1 peer2

修改完成,我们就来尝试搭建高可用的服务注册中心集群。接着上一章的服务中心的基础上面扩展,来构建一个双节点服务注册中心集群。

在resource目录下面:
创建application-peer1.yml配置文件,作为peer1服务中心的配置,并将serviceId指向peer2.

server:
  port: 8762
spring:
  application:
    name: service-register
eureka:
  instance:
    prefer-ip-address: false
    hostname: peer1
  client:
    fetch-registry: true
    register-with-eureka: true
    serviceUrl:
      defaultZone: http://peer2:8763/eureka/
  server:
    wait-time-in-ms-when-sync-empty: 0

创建application-peer2.yml配置文件,作为peer2服务中心的配置,并将serviceId指向peer1.

server:
  port: 8763
spring:
  application:
    name: service-register
eureka:
  instance:
    prefer-ip-address: false
    hostname: peer2
  client:
    fetch-registry: true
    register-with-eureka: true
    serviceUrl:
      defaultZone: http://peer1:8762/eureka/
  server:
    wait-time-in-ms-when-sync-empty: 0

接下来通过spring.profiles.active属性来分别启动peer1和peer2.
我启动的做法是不在idea里启动,而是把服务注册中心打包,通过cmd启动。
maven打包


img_e9c6d5d7bef5a5fa064aeb1da91c3b87.png
15324251491.jpg

然后通过cmd命令分别启动服务
[图片上传中...(15324253911.jpg-db47b5-1532490920148-0)]


img_f19773cff9b7f8364bc3a4bec0424342.png
15324254351.jpg

java -jar eureka-register-center-0.0.1-SNAPSHOT.jar --spring.profiles.active

img_6ba5a6eeaa5da3ed18ae0f6e5ac3a3c0.png
15324253911.jpg

java -jar eureka-register-center-0.0.1-SNAPSHOT.jar --spring.profiles.active=peer2

两个服务启动后,我们访问一下http://localhost:8762/或者http://localhost:8763/

img_9cd763114c7ecad679d0a661903a0d4a.png
15324255261.jpg

这里可以看到两个注册中心部署相互注册成功了。

关闭其中一个服务我们可以看到对应的节点变成不可用了。


img_1a09860744b4f032cf6eb34b5c57bc7b.png
15324256591.jpg

设置多个服务注册中心后,服务提供者还需要做一些简单的配置才能将服务注册到Eureka server集群中。

在这里我们按照前面的做法,重新新建一个服务提供者module,命名为"eureka-bussniss-service-user"当作是我们平时项目中用户服务模块,专门处理用户相关服务的。
因为目前服务注册中心是多个的,所以我们在服务提供者的配置文件上还需要做一些配置。
添加下面的属性,表示把服务注册到指定的注册中心,注册中心地址用逗号隔开;

eureka.client.serviceUrl.defaultZone=http://peer1:8762/eureka/,http://peer2:8763/eureka/

完整的application.yml配置如下:

spring:
  application:
    name: service-user
server:
  port: 8802
eureka:
  client:
      serviceUrl:
        defaultZone: http://peer1:8762/eureka/,http://peer2:8763/eureka/

记得主类添加@EnableEurekaClient注解,然后在确保服务注册中心正常的情况下,启动该项目。如果项目没有报错那就说明我们的配置应该是正常的。打开http://localhost:8763/或者http://localhost:8762/我们可以看到service-user已经同时注册到了服务注册中心。

img_e645bdf435fc0e173984201e3c0aa9f3.png
15324796051.jpg

此时若断开peer1服务,由于service-user服务也向peer2注册,因此peer2上面的其他服务依然能够访问到service-user。从而实现了注册中心的高可用。

项目的源码

服务提供者已经完成了,下一篇我们将会实现服务消费者,以及使用ribbon实现负载均衡。

目录
相关文章
|
1月前
|
存储 数据可视化 Java
基于MicrometerTracing门面和Zipkin实现集成springcloud2023的服务追踪
Sleuth将会停止维护,Sleuth最新版本也只支持springboot2。作为替代可以使用MicrometerTracing在微服务中作为服务追踪的工具。
86 1
|
17天前
|
自然语言处理 Java API
Spring Boot 接入大模型实战:通义千问赋能智能应用快速构建
【10月更文挑战第23天】在人工智能(AI)技术飞速发展的今天,大模型如通义千问(阿里云推出的生成式对话引擎)等已成为推动智能应用创新的重要力量。然而,对于许多开发者而言,如何高效、便捷地接入这些大模型并构建出功能丰富的智能应用仍是一个挑战。
71 6
|
2月前
|
设计模式 Java 关系型数据库
【Java笔记+踩坑汇总】Java基础+JavaWeb+SSM+SpringBoot+SpringCloud+瑞吉外卖/谷粒商城/学成在线+设计模式+面试题汇总+性能调优/架构设计+源码解析
本文是“Java学习路线”专栏的导航文章,目标是为Java初学者和初中高级工程师提供一套完整的Java学习路线。
374 37
|
1月前
|
负载均衡 网络协议 Java
浅谈Springboot与Springcloud的区别
浅谈Springboot与Springcloud的区别
35 1
|
2月前
|
消息中间件 存储 Java
SpringCloud基础9——服务异步通信-高级篇
消息可靠性、死信交换机、惰性队列、MQ集群
SpringCloud基础9——服务异步通信-高级篇
|
2月前
|
缓存 NoSQL Java
Springboot实战——黑马点评之秒杀优化
【9月更文挑战第27天】在黑马点评项目中,秒杀功能的优化对提升系统性能和用户体验至关重要。本文提出了多项Spring Boot项目的秒杀优化策略,包括数据库优化(如索引和分库分表)、缓存优化(如Redis缓存和缓存预热)、并发控制(如乐观锁、悲观锁和分布式锁)以及异步处理(如消息队列和异步任务执行)。这些策略能有效提高秒杀功能的性能和稳定性,为用户提供更佳体验。
135 6
|
2月前
|
Java API 对象存储
微服务魔法启动!Spring Cloud与Netflix OSS联手,零基础也能创造服务奇迹!
这段内容介绍了如何使用Spring Cloud和Netflix OSS构建微服务架构。首先,基于Spring Boot创建项目并添加Spring Cloud依赖项。接着配置Eureka服务器实现服务发现,然后创建REST控制器作为API入口。为提高服务稳定性,利用Hystrix实现断路器模式。最后,在启动类中启用Eureka客户端功能。此外,还可集成其他Netflix OSS组件以增强系统功能。通过这些步骤,开发者可以更高效地构建稳定且可扩展的微服务系统。
50 1
|
2月前
|
负载均衡 Java Nacos
SpringCloud基础1——远程调用、Eureka,Nacos注册中心、Ribbon负载均衡
微服务介绍、SpringCloud、服务拆分和远程调用、Eureka注册中心、Ribbon负载均衡、Nacos注册中心
SpringCloud基础1——远程调用、Eureka,Nacos注册中心、Ribbon负载均衡
|
3月前
|
Java API UED
【实战秘籍】Spring Boot开发者的福音:掌握网络防抖动,告别无效请求,提升用户体验!
【8月更文挑战第29天】网络防抖动技术能有效处理频繁触发的事件或请求,避免资源浪费,提升系统响应速度与用户体验。本文介绍如何在Spring Boot中实现防抖动,并提供代码示例。通过使用ScheduledExecutorService,可轻松实现延迟执行功能,确保仅在用户停止输入后才触发操作,大幅减少服务器负载。此外,还可利用`@Async`注解简化异步处理逻辑。防抖动是优化应用性能的关键策略,有助于打造高效稳定的软件系统。
70 2
|
3月前
|
JSON Java API
解码Spring Boot与JSON的完美融合:提升你的Web开发效率,实战技巧大公开!
【8月更文挑战第29天】Spring Boot作为Java开发的轻量级框架,通过`jackson`库提供了强大的JSON处理功能,简化了Web服务和数据交互的实现。本文通过代码示例介绍如何在Spring Boot中进行JSON序列化和反序列化操作,并展示了处理复杂JSON数据及创建RESTful API的方法,帮助开发者提高效率和应用性能。
133 0