当前位置: 首页 > news >正文

Eureka

大家好我是苏麟今天带来Eureka的使用 .

提供者和消费者

在服务调用关系中,会有两个不同的角色:

服务提供者:一次业务中,被其它微服务调用的服务。(提供接口给其它微服务)

服务消费者:一次业务中,调用其它微服务的服务。(调用其它微服务提供的接口)

但是,服务提供者与服务消费者的角色并不是绝对的,而是相对于业务而言。

如果服务A调用了服务B,而服务B又调用了服务C,服务B的角色是什么?

对于A调用B的业务而言:A是服务消费者,B是服务提供者

对于B调用C的业务而言:B是服务消费者,C是服务提供者

因此,服务B既可以是服务提供者,也可以是服务消费者。

Eureka注册中心

假如我们的服务提供者user-service部署了多个实例,如图:

 大家思考几个问题:

order-service在发起远程调用的时候,该如何得知user-service实例的ip地址和端口?

有多个user-service实例地址,order-service调用时该如何选择?

order-service如何得知某个user-service实例是否依然健康,是不是已经宕机?

Eureka的结构和作用

 问题1:order-service如何得知user-service实例地址?

获取地址信息的流程如下:

user-service服务实例启动后,将自己的信息注册到eureka-server(Eureka服务端)。这个叫服务 注册

eureka-server保存服务名称到服务实例地址列表的映射关系

order-service根据服务名称,拉取实例地址列表。这个叫服务发现或服务拉取

问题2:order-service如何从多个user-service实例中选择具体的实例?

order-service从实例列表中利用负载均衡算法选中一个实例地址 向该实例地址发起远程调用

问题3:order-service如何得知某个user-service实例是否依然健康,是不是已经宕机?

user-service会每隔一段时间(默认30秒)向eureka-server发起请求,报告自己状态,称为心跳 当超过一定时间没有发送心跳时,

eureka-server会认为微服务实例故障,将该实例从服务列表中 剔除 order-service拉取服务时,就能将故障实例排除了

因此,接下来我们动手实践的步骤包括:

搭建eureka-server

首先大家注册中心服务端:eureka-server,这必须是一个独立的微服务

创建eureka-server服务

 

Eureka使用

Eureka 的操作步骤


/*** eureka :* 1.引入 spring-cloud-starter-netflix-eureka-server 依赖* 2.在启动类上加 @EnableEurekaServer 开关注解* 3.在yml里配置信息*/

1.第一步 引入依赖

       <!--eureka服务端--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-server</artifactId></dependency>

2.第二步添加注解


/*** @EnableEurekaServer注解 Eureka开关注解 :开启Eureka*/
@EnableEurekaServer
@SpringBootApplication
public class EurekaApplication {public static void main(String[] args) {SpringApplication.run(EurekaApplication.class, args);}
}

3.添加配置信息

server:port: 10086 #服务端口
spring:application:name: eurekaserver # 服务名称#Eureka 配置信息
eureka:client:register-with-eureka: false   #是否将自己注册到eureka中fetch-registry: falseservice-url: # eureka 地址信息defaultZone: http://localhost:10086/eureka

启动服务

启动微服务,然后在浏览器访问:http://127.0.0.1:10086

看到下面结果应该是成功了:

服务注册

下面,我们将user-service注册到eureka-server中去。

引入依赖

在user-service的pom文件中,引入下面的eureka-client依赖:

    <!--eureka服务端--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId></dependency>

配置文件

server:port: 8081
spring:application:name: userserver # 服务名称
eureka:client:service-url: # eureka 地址信息defaultZone: http://localhost:10086/eureka

启动多个user-service实例

为了演示一个服务有多个实例的场景,我们添加一个SpringBoot的启动配置,再启动一个userservice。

首先,复制原来的user-service启动配置:

服务发现

下面,我们将order-service的逻辑修改:向eureka-server拉取user-service的信息,实现服务发现。

引入依赖

    <!--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: # eureka 地址信息defaultZone: http://localhost:10086/eureka

服务拉取和负载均衡

最后,我们要去eureka-server中拉取user-service服务的实例列表,并且实现负载均衡。 不过这些动作不用我们去做,只需要添加一些注解即可。

这期就到这里 , 下期见!

http://www.lryc.cn/news/183752.html

相关文章:

  • STM32G070RBT6-MCU温度测量(ADC)
  • 数据结构之带头双向循环链表
  • adb详细教程(四)-使用adb启动应用、关闭应用、清空应用数据、获取设备已安装应用列表
  • 【Spring Boot】日志文件
  • 图像处理与计算机视觉--第五章-图像分割-Canny算子
  • LabVIEW开发教学实验室自动化INL和DNL测试系统
  • 数据结构: 数组与链表
  • unity 控制玩家物体
  • 指数分布优化器(EDO)(含MATLAB代码)
  • Java 时间的加减处理
  • 基于A4988/DRV8825的四路步进电机驱动器
  • 万字总结网络原理
  • 【AI视野·今日CV 计算机视觉论文速览 第262期】Fri, 6 Oct 2023
  • 一文搞懂Jenkins持续集成解决的是什么问题
  • 微信小程序去除默认滚动条展示
  • 3.02 创建订单操作详细-订单创建与回滚 (创建订单操作详细)
  • 需求放缓、价格战升级、利润率持续恶化对小鹏汽车造成了严重影响
  • 《算法通关之路》chapter19解题技巧和面试技巧
  • 什么是TF-A项目的长期支持?
  • 【LinuxC】时间、时区,相关命令、函数
  • mac清理垃圾的软件有哪些?这三款我最推荐
  • 复习Day11:链表part04: 206. 反转链表、92. 反转链表II、25. K 个一组翻转链表、148. 排序链表
  • 一年一度的国庆节又结束了
  • 雷达干扰和烧穿范围简介
  • “秋天第一只大闸蟹”背后,看见京东一体化供应链
  • 大模型Java编码能力评估
  • javascript选择框和选择文本的创建与增加以及设置选中项
  • 汽车驾驶任务的隐马尔可夫模型识别方法研究
  • Java编程题(完数)
  • 国庆day6