作者:mobiledu2502861197 | 来源:互联网 | 2023-09-16 14:13
文章目录一、项目采用alibaba-Sentinel处理服务的降级熔断限流Sentinel具有以下特征:Sentinel的主要特性:二、使用1、引入POM:(父POM已经引入强依赖
文章目录
- 一、项目采用alibaba-Sentinel处理服务的降级熔断限流
- Sentinel 具有以下特征:
- Sentinel 的主要特性:
- 二、使用
- 1、引入POM:(父POM已经引入强依赖)
- 2、利用@ SentinelResource注解,进行资源埋点:
- 3、yml配置:
- 举例
- 在需要处理的方法上埋点,资源名为:sentinel-findById
- 控制台就可以看到(控制台单独部署,不依赖任何)
- 规则定义:(待完善)
- 异常处理类:
- 三、在Feign中使用:
- 1、yml配置 feign打开sentinel支持(注意:这里是指客户端配置,也就是调用方)
- 2、API模块新建fallback包,
- 3、实现FallbackFactory接口
- 4、在Feign接口中 添加fallbackFactory,如下图
- 四、在spring-cloud-gateway 中集成(待完善)
一、项目采用alibaba-Sentinel处理服务的降级熔断限流
Sentinel 具有以下特征:
- 丰富的应用场景:Sentinel 承接了阿里巴巴近 10 年的双十一大促流量的核心场景,例如秒杀(即突发流量控制在系统容量可以承受的范围)、消息削峰填谷、集群流量控制、实时熔断下游不可用应用等。
- 完备的实时监控:Sentinel 同时提供实时的监控功能。您可以在控制台中看到接入应用的单台机器秒级数据,甚至 500 台以下规模的集群的汇总运行情况。
- 广泛的开源生态:Sentinel 提供开箱即用的与其它开源框架/库的整合模块,例如与 Spring Cloud、Dubbo、gRPC 的整合。您只需要引入相应的依赖并进行简单的配置即可快速地接入 Sentinel。
- 完善的 SPI 扩展点:Sentinel 提供简单易用、完善的 SPI 扩展接口。您可以通过实现扩展接口来快速地定制逻辑。例如定制规则管理、适配动态数据源等。
Sentinel 的主要特性:
二、使用
1、引入POM:(父POM已经引入强依赖)
com.alibaba.cloud
spring-cloud-starter-alibaba-sentinel
2、利用@ SentinelResource注解,进行资源埋点:
注解包含以下属性:
3、yml配置:
Spring:
cloud:
sentinel:
transport:
dashboard: 127.0.0.1:8080 #sentinel控制台地址
# 取消Sentinel控制台懒加载
eager: true
举例
在需要处理的方法上埋点,资源名为:sentinel-findById
@Override
@SentinelResource(value = "sentinel-findById", blockHandler = "blockExceptionHandler", blockHandlerClass = {
ExceptionUtil.class})
public ResponseResult findById(@RequestBody @Valid RequestObject<StorageSelectDTO> requestObject) {
Storage one = storageService.getOne(Wrappers.<Storage>lambdaQuery().eq(Storage::getId, requestObject.getData().getId()));
return Objects.isNull(one)?ResponseResult.fail(StorageCode.FIND_FAIL):ResponseResult.success(one);
}
控制台就可以看到(控制台单独部署,不依赖任何)
控制台点击下载
规则定义:(待完善)
异常处理类:
项目中添加fallback包
package cn.geek.storage.fallback;
import cn.geek.common.model.base.BaseCode;
import cn.geek.common.model.pojo.RequestObject;
import cn.geek.common.model.pojo.ResponseResult;
import com.alibaba.csp.sentinel.slots.block.BlockException;
import com.alibaba.csp.sentinel.slots.block.authority.AuthorityException;
import com.alibaba.csp.sentinel.slots.block.degrade.DegradeException;
import com.alibaba.csp.sentinel.slots.block.flow.FlowException;
import com.alibaba.csp.sentinel.slots.block.flow.param.ParamFlowException;
import com.alibaba.csp.sentinel.slots.system.SystemBlockException;
import lombok.extern.slf4j.Slf4j;
/** * @version 1.0 * @Author Z.Y * @Description 此类定义@SentinelResource的属性 blockHandler 和fallbackHandler * @Date 2020/4/22 11:19 */
@Slf4j
public class ExceptionUtil {
/** * 对应@SentinelResource的属性 blockHandler * @param requestObject * @param e * @return */
public static ResponseResult blockExceptionHandler(RequestObject requestObject, BlockException e) {
log.info("Oops: " + e.getClass().getCanonicalName());
// 不同的异常返回不同的提示语
if (e instanceof FlowException) {
log.info("接口限流了");
return ResponseResult.fail("接口限流");
} else if (e instanceof DegradeException) {
log.info("服务降级了");
return ResponseResult.fail("服务熔断降级了");
} else if (e instanceof ParamFlowException) {
log.info("热点参数限流了");
return ResponseResult.fail("热点参数限流了");
} else if (e instanceof SystemBlockException) {
log.info("触发系统保护规则");
return ResponseResult.fail("触发系统保护规则");
} else if (e instanceof AuthorityException) {
log.info("触发系统保护规则");
return ResponseResult.fail("触发系统保护规则");
}
return ResponseResult.fail(BaseCode.CALL_TIME);
}
/** * 对应@SentinelResource的属性 fallbackHandler * @param requestObject * @param e * @return */
public static ResponseResult fallbackHandler(RequestObject requestObject, Throwable e) {
log.info("Oops: " + e.getClass().getCanonicalName());
// 不同的异常返回不同的提示语
if (e instanceof FlowException) {
log.info("接口限流了");
return ResponseResult.fail("接口限流");
} else if (e instanceof DegradeException) {
log.info("服务降级了");
return ResponseResult.fail("服务熔断降级了");
} else if (e instanceof ParamFlowException) {
log.info("热点参数限流了");
return ResponseResult.fail("热点参数限流了");
} else if (e instanceof SystemBlockException) {
log.info("触发系统保护规则");
return ResponseResult.fail("触发系统保护规则");
} else if (e instanceof AuthorityException) {
log.info("触发系统保护规则");
return ResponseResult.fail("触发系统保护规则");
}
return ResponseResult.fail(BaseCode.CALL_TIME);
}
}
三、在Feign中使用:
1、yml配置 feign打开sentinel支持(注意:这里是指客户端配置,也就是调用方)
feign:
sentinel:
enabled: true
2、API模块新建fallback包,
3、实现FallbackFactory接口
package cn.geek.storage.feigapi.fallback;
import cn.geek.common.model.base.BaseCode;
import cn.geek.common.model.pojo.RequestObject;
import cn.geek.common.model.pojo.ResponseResult;
import cn.geek.storage.feigapi.api.StorageApi;
import cn.geek.storage.feigapi.dto.StorageSelectDTO;
import cn.geek.storage.feigapi.entity.Storage;
import feign.hystrix.FallbackFactory;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Component;
/** * @version 1.0 * @Author Z.Y * @Description 熔断 * @Date 2020/4/21 19:57 */
@Component
@Slf4j
public class StorageApiFallbackFactory implements FallbackFactory<StorageApi> {
@Override
public StorageApi create(Throwable throwable) {
return new StorageApi() {
@Override
public ResponseResult findById(RequestObject<StorageSelectDTO> requestObject) {
log.info("findById熔断!",throwable);
return ResponseResult.fail(BaseCode.REQUEST_TIME_OUT);
}
@Override
public ResponseResult insert(RequestObject<Storage> requestObject) {
log.info("insert熔断!",throwable);
return ResponseResult.fail(BaseCode.REQUEST_TIME_OUT);
}
@Override
public ResponseResult deleteById(RequestObject<Storage> requestObject) {
log.info("deleteById熔断!",throwable);
return ResponseResult.fail(BaseCode.REQUEST_TIME_OUT);
}
@Override
public ResponseResult update(RequestObject<Storage> requestObject) {
log.info("update熔断!",throwable);
return ResponseResult.fail(BaseCode.REQUEST_TIME_OUT);
}
@Override
public ResponseResult findPage(RequestObject<StorageSelectDTO> requestObject) {
log.info("findPage熔断!",throwable);
return ResponseResult.fail("服务熔断降级!");
}
};
}
}
4、在Feign接口中 添加fallbackFactory,如下图
四、在spring-cloud-gateway 中集成(待完善)