1.Sentinel注解自定义资源实践
1.引入依赖:
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
<version>2.1.2.RELEASE</version>
</dependency>
2.加入sentinel控制面板
spring:
cloud:
sentinel:
transport:
dashboard: localhost
port: 8071
application:
name: mxw-api
3.添加资源注解
@SentinelResource(value = "limitBySecretKey",blockHandler = "handlerLimitBySecretKey")
4.控制台配置流控信息
5.实现服务降级返回信息
public String handlerLimitBySecretKey(String secretKey,BlockException e) {
String resource = e.getRule().getResource();
log.warn("handlerLimitBySecretKey|resource:{}|secretKey:{}",resource,secretKey);
throw new ApiValidateException("请求已超出最大限度,请稍后重试");
}
2.Sentinel手动代码配置自定义资源实践
// name: 资源名称,用于标识该调用。
// EntryType用于区分该资源是入口流量(inbound)还是出口流量(outbound),EntryType.IN代表入口流量,EntryType.OUT代表出口流量。
// count表示每次调用计数为多少,通常传1。
// args为传入的参数,用于热点参数限流。
try (Entry entry = SphU.entry(value,EntryType.IN,1,secretKey,ghId,appId)) {
log.info("HotParamRule|value:{}|token:{}",value,token);
} catch (BlockException ex) {
// 资源访问阻止,被限流或被降级
// 在此处进行相应的处理操作
log.warn("HandlerLimit|value:{}|token:{}",value,token);
throw new ApiValidateException("请求次数已超出最大限度,请稍后重试");
}