SpringCloud Alibaba微服务实战 - 限流熔断
本篇作为SpringCloud Alibaba微服务实战系列的第五篇,主要内容是使用Sentinel给微服务加上限流熔断功能,防止异常情况拖垮应用服务
简介
Sentinel是面向分布式服务框架的轻量级流量控制框架,主要以流量为切入点,从流量控制,熔断降级,系统负载保护等多个维度来维护系统的稳定性。 在SpringCloud体系中,Sentinel主要是为了替换原Hystrix的功能,与Hystrix相比,Sentinel的隔离级别更加精细,提供的Dashboard可以在线更改限流熔断规则,而且使用也越加方便。要了解更多详细信息请移步至Sentinel官网。
基础准备
要使用Sentinel提供的限流熔断能力,需要先做如下准备:
- 安装Sentinel
这部分内容我已经在第一期SpringCloud Alibaba微服务实战一 - 基础环境准备中已经实现了
- 引入Sentinel
在需要配置限流熔断服务的POM文件中引入Sentinel组件
<!--添加sentinel-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency>
自定义资源@SentinelResource
我们只需要在相关方法上加上@SentinelResource注解,让其可以成为sentinel识别的资源即可。如:
@GetMapping("/order/getAccount/{accountCode}")
@SentinelResource(value = "getAccount")
public Result getAccount(@PathVariable(value = "accountCode") String accountCode){
return accountFeign.getByCode(accountCode);
}
- 在配置文件中添加sentinel的服务端地址
server:
port: 8011
spring:
application:
name: order-service
cloud:
nacos:
discovery:
server-addr: 192.168.203.129:8848
sentinel:
transport:
# sentinel服务端地址
dashboard: 192.168.203.129:8080
# 取消延迟加载
eager: true
loadbalancer:
cache:
enabled: false
ribbon:
enabled: false
经过以上几步我们准备好了使用Sentinel的基础环境,接下来我们看看限流熔断的具体配置。
限流
概念说明
生产者accout-service是一个核心服务,我们通过压测得出服务的最大负载能力为60。如果某个时间account-service的请求数飙升达到了600,那服务肯定就直接gg了。所以为了保护我们的accout-service,我们会给它配置一个限流规则,如果每秒钟有超过60的请求那不好意思我直接丢掉不处理了,然后丢给消费者一个异常,想拖垮我,哼,没门!。
总而言之,限流是通过限制调用方对自己的调用,起到保护自己系统的效果。
限流配置
假设我们就将accout-service的QPS单机阈值设置成5,如果每秒QPS超过5,直接丢弃。