ps 官方文档:https://www.cnblogs.com/mrhelloworld/p/sentinel.html
1、下载地址:https://github.com/alibaba/Sentinel/releases根据自己需要下载对应版本,这里以sentinel-dashboard-1.8.0.jar为例
2、上传控制台jar包至linux服务器,启动sentinel控制台命(端口被占用请修改端口):
nohup java -Dserver.port=8081 -Dcsp.sentinel.dashboard.server=localhost:8081 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard-1.8.0.jar &
3、访问后台:http://localhost:8081,用户名、密码默认都为:sentinel,也可在启动命令中自行配置
4.熔断降级
Sentinel在1.8.0版本对熔断降级做了大的调整,可以定义任意时长的熔断时间,引入了半开启恢复支持。下面梳理下相关特性。
5、熔断状态
熔断有三种状态,分别为OPEN、HALF_OPEN、CLOSED
6、熔断策略
熔断降级支持慢调用比例、异常比例、异常数三种熔断策略。
先明确下面两个概念:慢调用:指耗时大于阈值RT的请求称为慢调用,阈值RT由用户设置
**最小请求数:**允许通过的最小请求数量,在最小请求数量内不发生熔断,由用户设置
6.1.慢调用比例
执行逻辑
熔断(OPEN):请求数大于最小请求数并且慢调用的比率大于比例阈值则发生熔断,熔断时长为用户自定义设置。
探测(HALFOPEN):当熔断过了定义的熔断时长,状态由熔断(OPEN)变为探测(HALFOPEN)。
如果接下来的一个请求小于最大RT,说明慢调用已经恢复,结束熔断,状态由探测(HALF_OPEN)变更为关闭(CLOSED)
如果接下来的一个请求大于最大RT,说明慢调用未恢复,继续熔断,熔断时长保持一致
注意Sentinel默认统计的RT上限是4900ms,超出此阈值的都会算作4900ms,若需要变更此上限可以通过启动配置项-Dcsp.sentinel.statistic.max.rt=xxx来配置
6.2.异常比例
通过计算异常比例与设置阈值对比的一种策略。
当资源的每秒请求数大于等于最小请求数,并且异常总数占通过量的比例超过比例阈值时,资源进入降级状态。
执行逻辑
熔断(OPEN):当请求数大于最小请求并且异常比例大于设置的阈值时触发熔断,熔断时长由用户设置。
探测(HALFOPEN):当超过熔断时长时,由熔断(OPEN)转为探测(HALFOPEN)
如果接下来的一个请求未发生错误,说明应用恢复,结束熔断,状态由探测(HALF_OPEN)变更为关闭(CLOSED)
如果接下来的一个请求继续发生错误,说明应用未恢复,继续熔断,熔断时长保持一致
6.3异常数
通过计算发生异常的请求数与设置阈值对比的一种策略
当资源近1分钟的异常数目超过阈值(异常数)之后会进行服务降级。注意由于统计时间窗口是分钟级别的,若熔断时长小于60s,则结束熔断状态后仍可能再次进入熔断状态。
执行逻辑
熔断(OPEN):当请求数大于最小请求并且异常数量大于设置的阈值时触发熔断,熔断时长由用户设置。
**探测(HALFOPEN):**当超过熔断时长时,由熔断(OPEN)转为探测(HALFOPEN)
如果接下来的一个请求未发生错误,说明应用恢复,结束熔断,状态由探测(HALF_OPEN)变更为关闭(CLOSED)
如果接下来的一个请求继续发生错误,说明应用未恢复,继续熔断,熔断时长保持一致
7.持久化json规则说明
熔断降级DegradeRule中的属性进行说明
属性说明
resource资源名称
grade降级策略 0:慢调用比例 1:异常比例 2:异常数量
count用户设置的阈值,根据不同的策略分别表示最大RT、异常比例阈值、异常数阈值
timeWindow熔断时长
minRequestAmount最小请求数,默认为5
slowRatioThreshold慢调用比率阈值,默认为1.0
statIntervalMs熔断时长,默认为1秒
四、规则格式示例
1.慢调用策略
[
{
"count":3000,
"grade":0,
"limitApp":"default",
"minRequestAmount":100,
"resource":"degrade01",
"slowRatioThreshold":0.5,
"statIntervalMs":1000,
"timeWindow":5
}
]
2.异常比例
{
"count":0.3,
"grade":1,
"limitApp":"default",
"minRequestAmount":200,
"resource":"degrade02",
"slowRatioThreshold":1,
"statIntervalMs":1000,
"timeWindow":5
}
3.异常数
{
"count":1000,
"grade":2,
"limitApp":"default",
"minRequestAmount":300,
"resource":"degrade03",
"slowRatioThreshold":1,
"statIntervalMs":1000,
"timeWindow":5
}