sentinel环境搭建
sentinel-dashboard搭建
限流中间件。启动默认接口8080
- 启动命令:java -jar sentinel-dashboard-1.8.2.jar
- 访问地址:localhost:8080
- 访问密码:sentinel/sentinel 如果端口占用,可以在启动命令中增加端口:
java -Dserver.port=8080 -Dcsp.sentinel.dashboard.server=localhost:8080 -Dproject.name=sentinel-dashboard -jar sentinel-dashboard.jar
应用接入sentinel
增加依赖
xml
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency>
增加配置
yaml
server:
port: 9001
spring:
application:
name: user
cloud:
discovery:
server-addr: 127.0.0.1:8848
sentinel:
transport:
dashboard: localhost:8080
port: 8720
management:
endpoint:
web:
exposure:
include:'*'
流控
簇点链路->选择需要流控的接口->+流控
- 资源名:路径,eg:/hello
- 针对来源:default,默认
- 阈值类型:QPS/并发线程数。
- QPS:一秒内请求路径次数
- 并发线程数:线程数
- 单机阈值:次数

- 流控模式:
- 直接:API达到限流条件时,直接限流
- 关联:当关联的资源达到阈值时,就限流自己
- 链路:只记录指定链路上的流量(指定资源从入口资源进来的流量,如果达到阈值,就进行限流)(API级别的针对来源)
- 流控效果:
- 快速失败:直接失败,抛异常
- Wam Up:根据codeFactor(冷加载因子,默认3)的值,从阈值/codeFacotor,经过预热时长,才达到设置的QPS阈值
- 排队等待:匀速排队,让请求以匀速的速度通过,阈值类型必须设置为QPS,否则无效
流控模式:直接/关联
这两种流控比较简单。直接就是当达到阈值,当前接口不能访问。关联是关联的资源达到阈值就限流自己。举一个关联的例子:下单和支付的关系。下单资源:/createOrder;支付资源:/payOrder。如果要配置关联可以在/payOrder配置一个关联/createOrder的限流。当/createOrder到达阈值,限制/payOrder的接口访问。
流控模式:链路
链路是比较细粒度的限流模式。比如接口A需要调用接口B,接口C需要调用接口B,我们将接口B做为资源。然后配置接口A限流,限流的方式是链路。那么当到达接口B的限流上限,接口A就无法访问,但是接口C还可以继续访问不受影响。
graph TD
接口A --> 接口B
接口C --> 接口B
接口B
定义资源使用@SentinelResource
java
@Service
public class UserService {
@SentinelResource("userName")
public String getUserName(){
return "sentinel";
}
}
调用接口B
java
@ApiOperation("s1")
@GetMapping("/s1")
public String s1(HttpServletRequest request){
System.out.println("s1");
String user = userService.getUserName();
return "hello s1 "+user+" ...9001";
}
调用接口A
less
@ApiOperation("s2")
@GetMapping("/s2")
public String s2(HttpServletRequest request){
System.out.println("s2");
String user = userService.getUserName();
return "hello s2"+user+" ...9001";
}
增加配置
新增:web-context-unify: false
yaml
server:
port: 9001
spring:
application:
name: user
cloud:
discovery:
server-addr: 127.0.0.1:8848
sentinel:
transport:
dashboard: localhost:8080
port: 8720
web-context-unify: false
management:
endpoint:
web:
exposure:
include:'*'
swagger:
enabled: true
sentinel注册信息

验证
被拒绝的请求如下:

流控效果:Warm Up
Warm Up使用场景:预热/冷启动方式。该方式主要用于系统长期处于低水位的情况下,当流量突然增加时,直接把系统拉升到高水位可能瞬间把系统压垮。通过"冷启动",让通过的流量缓慢增加,在一定时间内逐渐增加到阈值上限,给冷系统一个预热的时间,避免冷系统被压垮的情况。