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

相关推荐
动亦定20 分钟前
页面导出大量数据导致响应超时解决方案
java·mysql
q***062942 分钟前
解决 Tomcat 跨域问题 - Tomcat 配置静态文件和 Java Web 服务(Spring MVC Springboot)同时允许跨域
java·前端·spring
还是鼠鼠1 小时前
Redisson实现的分布式锁能解决主从一致性的问题吗?
java·数据库·redis·分布式·缓存·面试·redisson
d***95621 小时前
windows配置永久路由
java
王桑.2 小时前
IO流高级流--转换流
java
qq_12498707532 小时前
基于SpringBoot技术的企业请假审批管理系统的设计与实现(源码+论文+部署+安装)
java·spring boot·后端·信息可视化·毕业设计
BBB努力学习程序设计2 小时前
Java方法详解:提升代码复用性与可读性的利器
java
BBB努力学习程序设计2 小时前
Java运算符完全指南:让代码学会“计算”和“判断”
java
用户84913717547163 小时前
ThreadLocal 源码深度解析:JDK 设计者的“妥协”与“智慧”
java·后端
用户0304805912633 小时前
# 【Maven避坑】源码去哪了?一文看懂 Maven 工程与打包后的目录映射关系
java·后端