微服务下使用sentinel进行服务熔断

首先引入sentinel对应依赖

复制代码
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
</dependency>

下面是示例service代码,通过openFeign完成服务调用

复制代码
@Service
public class OrderServiceImpl implements OrderService {
    @Qualifier("com.example.orderservice.feign.UserFeign")
    @Autowired
    private UserFeign userFeign;
    @Override
    public Order getUserOrder(Integer userId) {
        System.out.println("开始服务间调用");
        return new Order(userFeign.getUserById(userId),1);
    }
}

首先需要配置openFeign的服务调用失败的策略,需要对对应的feign接口实现策略失败类

复制代码
//需要将这个类注册成为bean
@Component
public class UserFeignHystrixImpl implements UserFeign {
    @Override
    public User getUserById(Integer userId) {
        return new User(500,"已触发服务熔断,稍后再试");
    }
}

然后在feign的调用接口处,执行熔断策略实现类(fallback)

复制代码
@FeignClient(value = "user-service",fallback = UserFeignHystrixImpl.class)
public interface UserFeign {
    //这里采用springMVC的接口风格赋能方法,使得这个方法已经变成了服务生产者
    @GetMapping("user/getUserById")
    User getUserById(@RequestParam("userId") Integer userId);
}

然后需要下载阿里的sentinel-dashboard,启动控制台,并在该服务的配置文件中指定项目对应的控制台面板

复制代码
spring.cloud.sentinel.transport.dashboard=localhost:8080

至此就可以通过 sentinel-dashboard控制台来指定该服务的熔断触发条件以及规则,接口限流等.

相关推荐
0和1的舞者21 分钟前
Spring AOP详解(一)
java·开发语言·前端·spring·aop·面向切面
Wang153024 分钟前
Java多线程死锁排查
java·计算机网络
小小星球之旅44 分钟前
CompletableFuture学习
java·开发语言·学习
jiayong231 小时前
知识库概念与核心价值01
java·人工智能·spring·知识库
皮皮林5512 小时前
告别 OOM:EasyExcel 百万数据导出最佳实践(附开箱即用增强工具类)
java
Da Da 泓2 小时前
多线程(七)【线程池】
java·开发语言·线程池·多线程
To Be Clean Coder2 小时前
【Spring源码】getBean源码实战(三)
java·mysql·spring
Wokoo73 小时前
开发者AI大模型学习与接入指南
java·人工智能·学习·架构
电摇小人3 小时前
我的“C++之旅”(博客之星主题作文)
java·开发语言
资生算法程序员_畅想家_剑魔3 小时前
Java常见技术分享-23-多线程安全-总结
java·开发语言