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

微服务—Eureka注册中心

Eureka注册中心

    • 1.前言
    • 2.动手实践
      • 一.搭建eureka-server
      • 二服务注册
      • 三.服务发现

1.前言

假如我们的服务提供者user-service部署了多个实例,如图:
在这里插入图片描述
大家思考几个问题:

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

    回答之前的各个问题。

问题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将服务注册、服务发现等功能统一封装到了eureka-client端

2.动手实践

在这里插入图片描述

一.搭建eureka-server

1.创建eureka-server服务
注册中心服务端:eureka-server,这必须是一个独立的微服务

2.引入eureka依赖

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

3.编写启动类
添加一个@EnableEurekaServer注解,开启eureka的注册中心功能:

package cn.itcast.eureka;import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;@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

二服务注册

将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实例

三.服务发现

1.引入依赖

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

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

2.配置文件
在order-service的pom文件中,引入下面的eureka-client依赖:

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

3)服务拉取和负载均衡
最后,我们要去eureka-server中拉取user-service服务的实例列表,并且实现负载均衡。
在order-service的OrderApplication中,给RestTemplate这个Bean添加一个@LoadBalanced注解:
在这里插入图片描述
修改order-service服务中的cn.itcast.order.service包下的OrderService类中的queryOrderById方法。修改访问的url路径,用服务名代替ip、端口:
在这里插入图片描述
spring会自动帮助我们从eureka-server端,根据userservice这个服务名称,获取实例列表,而后完成负载均衡。

相关文章:

  • 快速上手Spring Cloud 六:容器化与微服务化
  • 为什么我的微信小程序 窗口背景色backgroundColor设置参数 无效的问题处理记录!
  • OpenCV 形态学处理函数
  • 视频推拉流EasyDSS点播平台云端录像播放异常的问题排查与解决
  • Arbitrum 为什么能领跑以太坊 Layer 2?
  • .htaccess配置重写url引擎
  • Android 14.0 SystemUI下拉状态栏增加响铃功能
  • 2024最新版克魔助手抓包教程(9) - 克魔助手 IOS 数据抓包
  • Django创建多app应用
  • 手机卫星通信
  • 设计模式(2):单例模式
  • Java安全篇-Fastjson漏洞
  • 堆的应用(堆排序,TOP-K问题)详细讲解
  • JAVA面试八股文之集合
  • 【STM32CubeMX(4)】 GPIO开漏输出——模拟IIC驱动OLED
  • JS中 map, filter, some, every, forEach, for in, for of 用法总结
  • python3.6+scrapy+mysql 爬虫实战
  • 【vuex入门系列02】mutation接收单个参数和多个参数
  • 2017-08-04 前端日报
  • 2018天猫双11|这就是阿里云!不止有新技术,更有温暖的社会力量
  • 4个实用的微服务测试策略
  • Centos6.8 使用rpm安装mysql5.7
  • CoolViewPager:即刻刷新,自定义边缘效果颜色,双向自动循环,内置垂直切换效果,想要的都在这里...
  • CSS3 变换
  • Go 语言编译器的 //go: 详解
  • IDEA 插件开发入门教程
  • JavaScript的使用你知道几种?(上)
  • PAT A1050
  • Vim Clutch | 面向脚踏板编程……
  • vue-cli3搭建项目
  • 不用申请服务号就可以开发微信支付/支付宝/QQ钱包支付!附:直接可用的代码+demo...
  • TPG领衔财团投资轻奢珠宝品牌APM Monaco
  • 继 XDL 之后,阿里妈妈开源大规模分布式图表征学习框架 Euler ...
  • ​2021半年盘点,不想你错过的重磅新书
  • ​如何在iOS手机上查看应用日志
  • #传输# #传输数据判断#
  • #我与Java虚拟机的故事#连载13:有这本书就够了
  • $L^p$ 调和函数恒为零
  • (3)STL算法之搜索
  • (M)unity2D敌人的创建、人物属性设置,遇敌掉血
  • (Python第六天)文件处理
  • (rabbitmq的高级特性)消息可靠性
  • (补)B+树一些思想
  • (机器学习-深度学习快速入门)第一章第一节:Python环境和数据分析
  • (力扣记录)1448. 统计二叉树中好节点的数目
  • (十)c52学习之旅-定时器实验
  • (十二)devops持续集成开发——jenkins的全局工具配置之sonar qube环境安装及配置
  • (四)【Jmeter】 JMeter的界面布局与组件概述
  • (详细版)Vary: Scaling up the Vision Vocabulary for Large Vision-Language Models
  • (一)ClickHouse 中的 `MaterializedMySQL` 数据库引擎的使用方法、设置、特性和限制。
  • (转)Google的Objective-C编码规范
  • (转)Windows2003安全设置/维护
  • .Net Core 中间件验签
  • .NetCore 如何动态路由
  • .net开发引用程序集提示没有强名称的解决办法