微服务下使用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控制台来指定该服务的熔断触发条件以及规则,接口限流等.

相关推荐
项目帮几秒前
Java毕设选题推荐:基于springboot区块链的电子病历数据共享平台设计与实现【附源码、mysql、文档、调试+代码讲解+全bao等】
java·spring boot·课程设计
心有—林夕20 分钟前
两个事务间的传播机制
java·事务
疯狂成瘾者23 分钟前
什么是多 Agent,多Agent是如何协作的?
java
he___H30 分钟前
Spring中的设计模式
java·spring·设计模式
liuyao_xianhui37 分钟前
优选算法_最小基因变化_bfs_C++
java·开发语言·数据结构·c++·算法·哈希算法·宽度优先
做一个AK梦38 分钟前
计算机系统概论知识点(软件设计师)
java·开发语言
東雪木1 小时前
Java学习——一访问修饰符(public/protected/default/private)的权限控制本质
java·开发语言·学习·java面试
两点王爷1 小时前
docker 创建和使用存储卷相关内容
java·docker·容器
boonya1 小时前
Embedding模型与向量维度动态切换完整方案
java·数据库·embedding·动态切换大模型
宁波阿成1 小时前
族谱管理系统架构分析与亮点总结
java·系统架构·vue·ruoyi-vue·族谱