早期我们一般认为的Spring Cloud五大组件是
-
Eureka : 注册中心
-
Ribbon : 负载均衡
-
Feign : 远程调用
-
Hystrix : 服务熔断
-
Zuul/Gateway : 网关
随着SpringCloudAlibba在国内兴起 , 我们项目中使用了一些阿里巴巴的组件
-
注册中心/配置中心 Nacos
-
负载均衡 Ribbon
-
服务调用 Feign
-
服务保护 sentinel
-
服务网关 Gateway
核心的功能就一下几个 :
-
服务注册 : 服务启动的时候会将服务的信息注册到注册中心, 比如: 服务名称 , 服务的IP , 端口号等
-
服务发现 : 服务调用方调用服务的时候, 根据服务名称从注册中心拉取服务列表 , 然后根据负载均衡策略 , 选择一个服务, 获取服务的IP和端口号, 发起远程调用
-
服务状态监控 : 服务提供者会定时向注册中心发送心跳 , 注册中心也会主动向服务提供者发送心跳探测, 如果长时间没有接收到心跳, 就将服务实例从注册中心下线或者移除
使用的话, 首先需要部署注册中心服务 , 然后在我们自己的微服务中引入注册中心依赖, 然后再配置文件中配置注册中心地址 就可以了
spring:
application:
name: leadnews-admin
cloud:
nacos:
# 注册中心地址
discovery:
server-addr: 124.221.75.8:8848
# 配置中心地址
config:
server-addr: 124.221.75.8:8848
file-extension: yml
项目负载均衡如何实现的
服务调用过程中的负载均衡一般使用SpringCloud的Ribbon 组件实现 , Feign的底层已经自动集成了Ribbon , 使用起来非常简单
客户端调用的话一般会通过网关, 通过网关实现请求的路由和负载均衡
spring:
cloud:
gateway:
routes:
# 平台管理
- id: we