首页 > 基础资料 博客日记
注册中心 —— SpringCloud Netflix Eureka
2023-08-13 12:20:38基础资料围观647次
Eureka 简介
Eureka 是一个基于 REST 的服务发现组件,SpringCloud 将它集成在其子项目 spring-cloud-netflix 中,以实现 SpringCloud 的服务注册与发现,同时提供了负载均衡、故障转移等能力,目前 Eureka2.0 已经不再维护,故不推荐使用
Eureka 有两种角色组件:
- Eureka Server:服务注册中心组件,提供了服务的注册与发现的接口
- Eureka Client:各种微服务,把自身的服务实例注册到 Eureka Server 中,也可通过 Eureka Server 获取服务列表,消费服务
微服务客户端在 Eureka 上注册,然后每隔 30 秒发送心跳来更新它们的租约。如果客户端不能多次续订租约,就将在大约 90 秒内从服务器注册表中剔除。注册信息和更新被复制到集群中的所有 Eureka 节点,来自任何区域的客户端都可以查找注册表信息(每30秒发生一次)来定位它们的服务并进行远程调用
搭建 Eureka 注册中心
创建 eureka-server 项目,引入依赖,本项目基于 SpringBoot 2.3.1,SpringCloud Hoxton.SR12
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
...
<dependencies>
在启动类上添加 @EnaleEurekaServer 注解,启用 Euerka 注册中心功能
@EnableEurekaServer
@SpringBootApplication
public class EurekaServerApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaServerApplication.class, args);
}
}
在配置文件添加 Eureka 服务端的配置
server:
port: 8001 # 指定运行端口
spring:
application:
name: eureka-server # 指定服务名称
eureka:
instance:
hostname: localhost # 指定主机名称
client:
fetch-registry: false # 指定能否从注册中心获取服务
register-with-eureka: false # 指定是否将服务注册到注册中心
运行 main 方法启动服务,在浏览器中访问 http://localhost:8001/ 便可以看到 Eureka 注册中心的界面
创建 eureka-client 项目,引入依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
在启动类上添加 @EnableDiscoveryClient 注解,表明是一个 Eureka 客户端
@EnableDiscoveryClient
@SpringBootApplication
public class EurekaClientApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaClientApplication.class, args);
}
}
在配置文件添加 Eureka 客户端的配置
server:
port: 8101 # 指定运行端口
spring:
application:
name: eureka-client # 指定服务名称
eureka:
client:
fetch-registry: true # 指定能否从注册中心获取服务
register-with-eureka: true # 指定是否将服务注册到注册中心
service-url:
defaultZone: http://localhost:8001/eureka
运行 main 方法,启动 eureka-client 项目,刷新 http://localhost:8001/ 页面,即可看到 cureka-client 已经注入 Eurcka 服务
搭建 Eureka 注册中心集群
由于所有服务都会注册到注册中心,服务之间的调用都是通过从注册中心获取服务列表来调用的。注册中心一旦宕机,所有服务调用都会出现问题,因此需要多个注册中心组成集群来提供服务
创建两个 eureka-server 项目,eureka-server-1 项目的配置文件如下:
server:
port: 8002 # 指定运行端口
spring:
application:
name: eureka-server-1 # 指定服务名称
eureka:
instance:
hostname: localhost # 指定主机名称
client:
fetch-registry: true # 指定能否从注册中心获取服务
register-with-eureka: true # 指定是否将服务注册到注册中心
service-url:
defaultZone: http://localhost:8003/eureka/
eureka-server-2 项目的配置文件如下:
server:
port: 8003 # 指定运行端口
spring:
application:
name: eureka-server-1 # 指定服务名称
eureka:
instance:
hostname: localhost # 指定主机名称
client:
fetch-registry: true # 指定能否从注册中心获取服务
register-with-eureka: true # 指定是否将服务注册到注册中心
service-url:
defaultZone: http://localhost:8002/eureka/
通过两个注册中心互相注册,搭建注册中心的双节点集群。分别启动项目,查看 http://localhost:8001/ 和 http://localhost:8002/,可以看到两个注册中心已经分别注册了
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
标签:
上一篇:SpringBoot3集成Quartz
下一篇:Java正则表达式
相关文章
最新发布
- HEIC 批量转 JPG - 一键转换苹果 HEIC 格式为 JPG/PNG,保留 EXIF 信息,支持批量处理
- 【php】老旧PHP项目(PHP 5.6)本地环境搭建与踩坑记录
- Vue3 轻量安全滑动拼图验证码:vue-sliding-puzzle 上手全攻略
- 多市场行情时间戳对齐:UTC 存储的夏令时陷阱与数据库设计方案
- 15. 别再硬写提示词了!LangChain ChatPromptTemplate核心实战
- 一次 OOM 线上排查实录
- 从控制论看 Harness Engineering:当反馈回路终于能在"重要的地方"闭合
- AI 测试全场景提效:功能 / 性能 / 安全 / 自动化,用 AI 重塑测试工作流
- 你真的理解 volatile 关键字了吗?
- .NET 11 Preview 4 震撼发布:MAUI 抛弃 Mono,全量迁移 CoreCLR,性能与 NativeAOT 双炸场!

