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(负载均衡)(拉取服务)--- 选择服务返回响应

posted @   K-smiles  阅读(16)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· Ollama——大语言模型本地部署的极速利器
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示