SpringCloud(二) Eureka注册中心的使用

在SpringCloud(一)中,我们学会了使用RestTemplate进行远程调用,但是在调用user-service时候需要在order-service中发送http请求,请求中需要书写对应微服务的ip和端口号,十分不方便,如果此时有多个user-service实例的话,就不知道调用哪个了(除非每次调用的时候都对ip和端口号进行调整),所以本篇博客将介绍一个专门用来进行服务注册的组件----Eureka.

目录

一, Eureka的机构和作用

1.1 RestTemplate存在的问题

1.2 Eureka的结构和作用

二, Eureka的使用

2.1 Eureka的使用步骤

 2.2 搭建eureka-server

1, 创建eureka-server服务

 2, 引入eureka依赖

3, 编写启动类

4, 编写配置文件 

5, 启动eureka-server

2.3 服务注册

1, 引入依赖

2, 配置文件 

3, 启动多个user-service实例

2.4 服务发现

1, 引入依赖

2, 配置文件

3, 服务拉取和负载均衡

2.5 Eureka的使用示例


一, Eureka的机构和作用

1.1 RestTemplate存在的问题

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

大家需要思考几个问题:

  • order-service在发起远程调用的时候,该如何得知user-service实例的ip和端口?
  • 有多个user-service实例地址,order-service调用时该如何选择?
  • order-service如何得知某个user-service实例是否依然健康,是不是已经宕机? 

1.2 Eureka的结构和作用

上述问题都需要利用SpringCloud中的注册中心来解决,其中最广为人知的注册中心就是Eureka,Eureka的结构如图所示:

order-service如何得知user-service实例地址?

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

  • user-service服务实例启动后,将自己的信息注册到eureka-server(Eureka服务端),这个叫服务注册;
  • eureka-server保存服务名称到服务实例地址列表的映射关系;
  • order-service根据服务名称,拉取实例地址列表,这个叫服务发现或服务拉取.

order-service如何从多个user-service实例中选择具体端的实例?

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

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

  •  user-service会每隔一段时间(默认是30s)向eureka-service发起请求,报告自己状态,称为心跳;
  • 当超过一定时间没有心跳时,eureka-server会认为微服务实例故障,将该实例从服务列表中剔除;
  • order-service拉取服务时,就能将故障实例排除了. 

一个微服务,既可以是服务提供者,又可以是服务消费者,因此eureka将服务注册,服务发现等功能统一封装到了eureka-client端.

二, Eureka的使用

2.1 Eureka的使用步骤

  

 2.2 搭建eureka-server

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

1, 创建eureka-server服务

在cloud-demo父工程下,创建一个子模块:

 填写模块信息:

 

填写服务信息:

 2, 引入eureka依赖

引入SpringCloud为eureka提供的starter依赖:

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

3, 编写启动类

给eureka-server服务编写一个启动类,一定要添加一个@EnableEurekaServer注解,表示开启eureka的注册中心功能:

@SpringBootApplication
@EnableEurekaServer
public class EurekaApplication {public static void main(String[] args) {SpringApplication.run(EurekaApplication.class, args);}
}

4, 编写配置文件 

编写一个application.yml文件,内容如下:

server:port: 10086 //端口可以写成任意的 只要不冲突就行
spring:application:name: eureka-server
eureka:client:service-url: defaultZone: http://127.0.0.1:10086/eureka

5, 启动eureka-server

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

看到一下页面表示启动成功:

2.3 服务注册

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

1, 引入依赖

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

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

2, 配置文件 

在user-service中,修改application.yml文件,添加服务名称,eureka地址:

spring:application:name: userservice
eureka:client:service-url:defaultZone: http://127.0.0.1:10086/eureka

3, 启动多个user-service实例

为了演示一个服务有多个实例的场景,我们添加一个SpringBoot的启动装置,再启动一个user-service

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

填写信息,使用不同的端口号:

 此时有两个user-service,端口号分别是8081和8082,启动两个实例:

 此时可以看到在eureka-server的管理页面中可以看到已经注册了两个user-service实例了.

2.4 服务发现

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

1, 引入依赖

服务发现和服务注册统一封装在eureka-client依赖中,因此这一步与服务注册一致,在order-service的pom文件中,引入eureka-client依赖:

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

2, 配置文件

服务发现也需要eureka地址,因此第二步与服务注册一致,都是配置eureka信息,在order-service中修改application.yml文件,添加服务名称.eureka地址:

spring:application:name: orderservice
eureka:client:service-url:defaultZone: http://127.0.0.1:10086/eureka

3, 服务拉取和负载均衡

启动order-service之后可以发现order-service也被注册到了eureka-server中:

此时我们就可以去eureka-server中拉取user-service服务的实力列表,并且实现负载均衡,这一系列的操作只需要添加一些注解即可

负载均衡内容详细博客:SpringCloud(三) Ribbon负载均衡-CSDN博客

在order-service的OrderApplication中,给RestTemplate这个Bean添加一个@LoadBalance注解:

修改order-service服务中的cn.itcast.order.service包下的OrderService类中的queryOrderById方法,修改访问的url路径,用服务名代替ip,端口:

Spring会自动帮我们从eureka-server端,根据userservice这个服务名称,获取实例列表,而后完成负载均衡.

2.5 Eureka的使用示例

此时,我们已经将order-service和user-service都注册到了eureka-server中,就可以通过order-service发现服务从而给user-service服务发送http请求进而获取到用户的信息:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/176841.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

论文-分布式-并发控制-并发控制问题的解决方案

目录 参考文献 问题 解法与证明 易读版本 参考文献 Dijkstra于1965年发表文章Solution of a Problem in Concurrent Programming Control&#xff0c;引出并发系统下的互斥(mutual exclusion)问题&#xff0c;自此开辟了分布式计算领域Dijkstra在文中给出了基于共享存储原子…

sqlite3 关系型数据库语言 SQL 语言

SQL(Structured Query Language)语言是一种结构化查询语言,是一个通用的,功能强大的关系型数据库操作语言. 包含 6 个部分: 1.数据查询语言(DQL:Data Query Language) 从数据库的二维表格中查询数据,保留字 SELECT 是 DQL 中用的最多的语句 2.数据操作语言(DML) 最主要的关…

易点天下受邀参与云栖大会,以AIGC重塑出海营销新范式

10月31日&#xff0c;2023云栖大会在杭州云栖小镇拉开帷幕。与往年不同&#xff0c;今年的云栖大会以“计算&#xff0c;为了无法计算的价值”为主题&#xff0c;与国际潮流科技大会组织方式接轨&#xff0c;通过云计算、人工智能、产业创新三大主题馆40000平科技展&#xff0c…

redis缓存穿透

redis缓存穿透 模拟一个缓存穿透的环境&#xff1a; redis缓存穿透1. 准备一个GET请求并且在第一次访问的时候将数据写入缓存2. 再次访问的时候首先判断缓存是否命中3. 命中了直接返回&#xff0c;未命中重建缓存1. 缓存空对象2. 布隆过滤器 1. 准备一个GET请求并且在第一次访问…

avi怎么转mp4?

avi怎么转mp4&#xff1f;如今市面上涌现了各种多样的视频格式&#xff0c;其中AVI作为一种音频视频交错格式&#xff0c;虽然使用较少但相对常见。它的优点在于占用空间较小&#xff0c;但画面质量并不是很出色。然而&#xff0c;AVI格式也存在一个明显的缺点&#xff0c;即兼…

柯桥专升本学校,自考本科文凭的价值如何?

自考本科文凭的价值如何&#xff1f; 自考本科学历是通过独立学习和考试获得的一种本科学历。对于自考本科学历的价值&#xff0c;很多人感到困惑&#xff0c;那么究竟自考本科学历有多大的价值呢? 首先&#xff0c;在就业市场上&#xff0c;自考本科学历具有一定的竞争力。随…

VBA技术资料MF77:组合所选范围中的所有形状

我给VBA的定义&#xff1a;VBA是个人小型自动化处理的有效工具。利用好了&#xff0c;可以大大提高自己的工作效率&#xff0c;而且可以提高数据的准确度。我的教程一共九套&#xff0c;分为初级、中级、高级三大部分。是对VBA的系统讲解&#xff0c;从简单的入门&#xff0c;到…

横屏签字板手写签名并旋转90°转为横屏显示base64

手写签名并旋转90转为横屏显示base64 base64 data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAApsAAAF3CAYAAADq/IAAAAAAAXNSR0IArs4c6QAAIABJREFUeF7t3W3MPlldH/CvwLK7wEKNoiABZLvYiBqIdJGnQlor9gVBaAtJmzQsoI2wgKD4hqVNmrD7ohWhPFRSIgaKO0XTS8AVLb4AIVtFnaSiMPSktxoyVVWFxAF…

我的云栖大会之旅:见证云计算创新的15年

云栖大会&#xff0c;曾经是一次不可思议的科技之旅&#xff0c;却如今已见证了我对云计算世界的15年关注和发展。第一次踏上云栖大会之旅&#xff0c;我记得是在2009年。那时的云计算还是一个新生事物&#xff0c;而云栖大会正是其中的奠基石。 我清楚地记得那个炎热的夏天&am…

OpenCV标定演示,及如何生成标定板图片

标定的程序在官方的源码里有&#xff0c; opencv-4.5.5\samples\cpp\tutorial_code\calib3d\camera_calibration 很多小白不知道怎么跑起来&#xff0c;这个也怪OpenCV官方&#xff0c;工作没做完善&#xff0c;其实的default.xml是要自己手动改的&#xff0c;输入的图片也要…

【QT】鼠标常用事件

新建项目 加标签控件 当鼠标进去&#xff0c;显示【鼠标进入】&#xff0c;离开时显示【鼠标离开】 将QLable提升成自己的控件&#xff0c;然后再去捕获 添加文件 改继承的类名 提升类 同一个父类&#xff0c;可以提升 效果 现在代码就和Qlabel对应起来了。 在.h中声明&…

Linux———— 运算命令

Shell与其他编程语言一样&#xff0c;支持多种类型的运算符&#xff0c;包括&#xff1a; 算术运算符&#xff1a;用于执行数学运算&#xff0c;例如加法、减法、乘法和除法。 关系运算符&#xff1a;用于比较两个值之间的关系&#xff0c;例如相等、大于、小于等。 布尔运算…

FPGA 如何 固化程序到 FLASH中

1、导出Hardware 2、导出bit文件 3、打开SDK 4、 点击Ok 5、创建工程 6、 输入工程名称&#xff1a;guhua 7、选择 Zynq FSBL 8、单击 guhua、然后点击 build 点击&#xff1a;build all 9、 右键之后&#xff0c;点击&#xff1a;Creat Boot Image 10、点击 Cr…

项目解读_v2

1. 项目介绍 如果使用task2-1作为示例时&#xff0c; 运行process.py的过程中需要确认 process调用的是函数 preprocess_ast_wav2vec(wav, fr) 1.1 任务简介 首个开源的儿科呼吸音数据集&#xff0c; 通过邀请11位医师标注&#xff1b; 数字听诊器的采样频率和量化分辨率分…

大厂面试题-网络四元组

四元组&#xff0c;简单理解就是在TCP协议中&#xff0c;去确定一个客户端连接的组成要素&#xff0c;它包括源 IP地址、目标IP地址、源端口号、目标端口号。 正常情况下&#xff0c;我们对于网络通信的认识可能是这样(如图)。 服务端通过Server Socket建立一个对指定端口号…

商城性能测试LoadRunner快速上手教学

软件介绍 Virtual User Generator &#xff0c;记录用户流程并创建一个自动化性能测试脚本Controller&#xff0c;单一控制点&#xff0c;轻松、有效地控制所有Vuser&#xff0c;执行期间监控场景性能Analysis&#xff0c;生成性能测试报告&#xff0c;以图表形式呈现。 由于…

UE5使用Dash插件实现程序化地形场景制作

目录 0 dash下载后激活 1 初步使用 2 导入bridge的资产路径 3 练习成果 4 参考链接 0 dash下载后激活 1 初步使用 Dash插件点击蓝色的A&#xff0c;可以使用。 通过输入不同提示命令&#xff0c;来激活不同的功能。 2 导入bridge的资产路径 这里需要注意是UAsserts…

解决Linux Debian12系统中安装VirtualBox虚拟机无法使用USB设备的问题

Debian12系统中安装VirtualBox&#xff0c;再VirtualBox虚拟机中无法使用 USB设备。如下图所示&#xff1a; 解决方法如下&#xff1a; 1.安装 Virtualbox增强功能。如下图所示&#xff1a; 2.添加相关用户、用户组&#xff08; Virtualbox 装完成后会有 vboxusers 和 vboxs…

Vue:实现输入vue组件名称,就可以从网页上加载出组件

作者:CSDN @ _乐多_ 本文记录了使用动态组件实现在网页上输入vue组件名称,就可以从网页上直接加载组件的功能的代码。 实现效果如下所示, 在许多Vue.js应用中,我们有大量的组件,但并不是每个组件都需要在应用初始化时加载。动态加载组件的好处包括: 减小初始加载时间:…