消费者和提供者
之前远程调用使用restTemplate来发送http请求获取服务,
当地址改变,需要修改代码(硬编码),当有多个地址可提供服务,该选择那个?
Eureka注册中心
当服务启动时,Eureka注册中心会将服务信息记录下来,当有服务需要其它服务,则通过Eureka来寻找服务。
服务会每隔30s发送心跳续约到Eureka,告知其服务依然存在
在Eureka中,微服务角色分为两类:
- EurekaServer:服务端,注册中心
负责记录服务信息,心跳监控 - EurekaClient:客户端
Provider:服务提供者,将自己的信息注册到EurekaServer
consumer:服务消费者,根据服务名称从EurekaServer拉取服务列表,基于服务列表做负载均衡,选中一个微服务来提供服务
搭建Eureka服务
服务中心的搭建
创建一个新的module,引入依赖
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
name: orderserver #服务名称
eureka:
client:
service-url:
defaultZone: http://127.0.0.1:10086/eureka
服务的拉取
在restTemplate基础上进行修改
url 地址前缀修改为服务名称,给restTemplate配置添加@LoadBalance
服务的负载均衡
负载均衡流程
服务端发起请求 ----- Ribbon(负载均衡)(拉取服务)--- 选择服务返回响应