1.引入依赖
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-sentinel</artifactId></dependency>
2.yaml
spring:cloud:sentinel:transport:dashboard: localhost:8090 #sentinel控制台地址http-method-specify: true # 是否设置请求方式作为资源名称
feign:sentinel:enabled: true # 开启feign对sentinel的支持
3.降级
3.1 引入依赖
<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-sentinel</artifactId></dependency>
3.2 创建降级方案
触发限流或熔断后的请求不一定要直接报错,也可以返回一些默认数据或者友好提示,用户体验会更好。
给FeignClient编写失败后的降级逻辑有两种方式:
- 方式一:FallbackClass,无法对远程调用的异常做处理
- 方式二:FallbackFactory,可以对远程调用的异常做处理,我们一般选择这种方式。
这里我们演示方式二的失败降级处理。
步骤一:在hm-api模块中给ItemClient定义降级处理类,实现FallbackFactory
@Component
public class ItemClientFallBackFactory implements FallbackFactory<ItemClient> {@Overridepublic ItemClient create(Throwable cause) {return new ItemClient() {@Overridepublic PageDTO<ItemDTO> queryItemByPage(PageQuery query) {//这里写降级逻辑return null;}@Overridepublic List<ItemDTO> queryItemByIds(List<Long> ids) {//这里写降级逻辑return List.of();}};}
}
步骤二: 在hm-api模块中的ItemClient接口中使用ItemClientFallbackFactory:
@FeignClient("item-service", fallbackFactory = ItemClientFallBackFactory.class)
public interface ItemClient {@GetMapping("/items/page")PageDTO<ItemDTO> queryItemByPage(PageQuery query);@GetMapping("/items")List<ItemDTO> queryItemByIds(@RequestParam("ids") List<Long> ids);