什么是 Sentinel?

Sentinel 是阿里巴巴开源的面向分布式服务架构的高可用流量防护组件,随着微服务的流行,服务和服务之间的稳定性变得越来越重要,Sentinel 以流量为切入点,从流量控制、熔断降级、系统负载保护等多个维度保护服务的稳定性。

安装 Sentinel 控制台

  • 下载 Sentinel 源码及 jar 包,Github Sentinel 地址
  • 运行命令: java -jar sentinel-dashboard-xxx.jar 。

Sentinel 启动界面如下:

在这里插入图片描述

Sentinel 默认端口 8080,Sentinel 控制台界面如下:

在这里插入图片描述

Sentinel 默认账号密码都是:sentinel,首次登录 Sentinel 界面如下:

在这里插入图片描述

微服务整合 Sentinel

1.pom.xml 引用 Sentinel 依赖,如下:

<dependency>
	<groupId>com.alibaba.cloud</groupId>
	<artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
	<version>2021.1</version>
</dependency>

2.配置文件添加 Sentinel 控制台配置,如下:

spring.cloud.sentinel.transport.dashboard=localhost:8080

3.测试 Sentinel 控制台效果,如下:

测试代码:

@Slf4j
@RestController
public class SentinelController {

    @GetMapping("/test-sentinel")
    public String test() {
        return "hello~sentinel";
    }

}

测试接口页面:

在这里插入图片描述

Sentinel 页面:

在这里插入图片描述

Sentinel 控制台是懒加载的,只有访问了服务的接口才会在 Sentinel 上看到监控。

Sentinel 流控

流控,顾名思义流量控制,在控制台设置 QPS 和线程数的流控规则,当请求超过限定的 QPS 或服务器线程数超过指定值时,自动拒绝请求。

流控模式:

  • 直接:直接就没什么好说的了,就是单纯的流控当前资源。
  • 关联:当资源1达到限流阀值后,对资源2进行限流,防止资源1更多的被调用。
  • 链路:当链路流控可在业务层指定某个链路进行控流。

流控效果:

  • 快速失败:直接拒绝请求。
  • 预热(Warm Up):通过预热时间的设置,随着时间的加载,请求慢慢到达设置 QPS。
  • 排队:当请求 QPS 达到设定的 QPS 之后,后续请求进行排队,但是排队时间是有限制的,会设定一个排队时间。

配置流控界面:
在这里插入图片描述

Sentinel 降级

Sentinel 降级实在业务发生之后进行统计,根据不同情况触发熔断。

熔断策略:

  • 慢调用比例:慢调用比例会根据设置的最大 RT 来统计慢调用次数,计算出慢调用比例,超过设定的慢调用比例之后,Sentinel 会根据熔断时长对资源进行熔断。
  • 异常比例:异常比例会统计异常调用次数,计算出异常调用比例,超过设定的异常调用比例之后,Sentinel 会根据熔断时长对资源进行熔断。
  • 异常数:统计异常调用数量,超过设定的异常调用数之后,Sentinel 会根据熔断时长对资源进行熔断。

Sentinel 降级配置界面:
在这里插入图片描述

Sentinel 热点规则

通过利用热点 key,发现哪些查询参数属于热点数据,需要对热点数据进行限流,以保证热点数据的处理不会影响系统整体性能。

Sentinel 热点规则配置界面:
在这里插入图片描述

Sentinel 授权规则

授权规则涉及接口的权限管理,需要在系统中添加接口实现类,获取请求中的权限信息,在 Sentinel 控制台中配置白名单和黑名单,对访问资源进行管控。

Sentinel 授权规则配置界面:

在这里插入图片描述

Sentinel 流控规则测试

配置了一个 QPS 阀值为 1 的流控规则,如图所示:

在这里插入图片描述

测试结果如下:

在这里插入图片描述

当每秒请求超过一个的时候,会触发流控规则,触发 Blocked by Sentinel (flow limiting) 错误,失败直接返回。

欢迎提出建议及对错误的地方指出纠正。

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐