Hystrix
Hystrix是国外知名的视频网站Netflix所开源的非常流行的高可用架构框架。Hystrix能够完美的解决分布式系统架构中打造高可用服务面临的一系列技术难题。
Hystrix “豪猪”,具有自我保护的能力。hystrix 通过如下机制来解决雪崩效应问题。
资源隔离(限流):包括线程池隔离和信号量隔离,限制调用分布式服务的资源使用,某一个调用的服务出现问题不会影响其他服务调用。
融断:当失败率达到阀值自动触发降级(如因网络故障/超时造成的失败率高),熔断器触发的快速失败会进行快速恢复。
降级机制:超时降级、资源不足时(线程或信号量)降级,降级后可以配合降级接口返回托底数据。
缓存:提供了请求缓存、请求合并实现。
Hystrix 的实现
提供者
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>
主类
加上@EnableHystrix //等同于@EnableCircuitBreaker注解
@EnableHystrix //等同于@EnableCircuitBreaker
public class EhrRunApp {
public static void main(String[] args) {
SpringApplication.run(EhrRunApp.class,args);
}
}
服务代码:
1.加上@HystrixCommand(fallbackMethod = "failGet")
fallbackMethod 服务错误返回的方法0
public class UserController {
@RequestMapping("/getEmp/{id}")
@HystrixCommand(fallbackMethod = "failGet")
public Object getEmp(@PathVariable("id") Integer id){
if(id==2){
throw new RuntimeException("报错了!");
}
Emp emp=new Emp();
emp.setId(id);
emp.setUsername("kd");
return emp;
}
public Emp failGet(Integer id){
Emp emp=new Emp();
emp.setId(id);
emp.setUsername("用户名不存在");
return emp;
}
}
今天的文章springcloud入门教程_docker技术入门与实战分享到此就结束了,感谢您的阅读。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/69505.html