Eureka
消费者和提供者
Eureka是Spring Cloud Netflix的一个子模块,也是核心模块之一。Eureka是一个基于REST的服务,用于定位服务,以及·实现云端中间层服务发现和故障转移。服务注册与发现对于微服务架构来说是非常重要的,有了服务发现与注册,只需要使用服务的标识符,就可以访问到服务,而不需要修改服务调用的配置文件了。功能类似于dubbo的注册中心,比如Zookeeper。
之前远程调用使用restTemplate来发送http请求获取服务,
当地址改变,需要修改代码(硬编码),当有多个地址可提供服务,该选择那个?
Eureka注册中心
当服务启动时,Eureka注册中心会将服务信息记录下来,当有服务需要其它服务,则通过Eureka来寻找服务。
服务会每隔30s发送心跳续约到Eureka,告知其服务依然存在
在Eureka中,微服务角色分为两类:
- EurekaServer:服务端,注册中心
负责记录服务信息,心跳监控 - EurekaClient:客户端
Provider:服务提供者,将自己的信息注册到EurekaServer
consumer:服务消费者,根据服务名称从EurekaServer拉取服务列表,基于服务列表做负载均衡,选中一个微服务来提供服务
搭建Eureka服务
服务中心的搭建
创建一个新的module,引入依赖
在启动类要添加注解 @EnableEurekaServer
artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
编写配置文件
点击查看代码
server:
port: 10086 # 服务端口
spring:
application:
name: eurekaserver #服务名称
eureka:
client:
service-url:
defaultZone: http://127.0.0.1:10086/eureka
服务提供者的注册
引入依赖
点击查看代码
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
编写配置
点击查看代码
server:
port: 8080
spring:
application:
name: orderserver #服务名称
eureka:
client:
service-url:
defaultZone: http://127.0.0.1:10086/eureka
服务的拉取
在restTemplate基础上进行修改
url 地址前缀修改为服务名称,给restTemplate配置添加@LoadBalance
服务的负载均衡
负载均衡流程
服务端发起请求 ----- Ribbon(负载均衡)(拉取服务)--- 选择服务返回响应
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Ollama——大语言模型本地部署的极速利器
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现