SpringCloud微服务(03):Hystrix组件,实现服务熔断
本文源码:GitHub·点这里 || GitEE·点这里
一、熔断器简介
微服务架构特点就是多服务,多数据源,支撑系统应用。这样导致微服务之间存在依赖关系。如果其中一个服务故障,可能导致系统宕机,这就是所谓的雪崩效应。
1、服务熔断
微服务架构中某个微服务发生故障时,要快速切断服务,提示用户,后续请求,不调用该服务,直接返回,释放资源,这就是服务熔断。
熔断生效后,会在指定的时间后调用请求来测试依赖是否恢复,依赖的应用恢复后关闭熔断。
2、服务降级
服务器高并发下,压力剧增的时候,根据当业务情况以及流量,对一些服务和页面有策略的降级(可以理解为关闭不必要的服务),以此缓解服务器资源的压力以保障核心任务的正常运行。
双十一期间,支付宝很多功能都会提示,[双十一期间,保障核心交易,某某服务数据延迟]。
3、核心依赖
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-hystrix</artifactId> </dependency>
4、核心注解
- @EnableHystrix 启动类注解控制熔断功能。
- @HystrixCommand 方法注解,熔断控制配置。
5、案例模块描述
演示基于Ribbon服务的熔断 node03-consume-8001 演示基于Feign服务的熔断 node03-consume-8002 Eureka注册中心 node03-eureka-7001 两个服务提供方 node03-provider-6001 node03-provider-6002
二、基于Ribbon服务熔断
1、熔断执行方法
/** * 服务熔断调用方法 */ public String getDefaultInfo (){ return "服务被熔断" ; }
2、简单案例
/** * 简单配置 */ @RequestMapping("/showInfo1") @HystrixCommand(fallbackMethod = "getDefaultInfo") public String showInfo1 (){ return restTemplate.getForObject(server_name+"/getInfo",String.class) ; }
Hystrix默认的超时时间是1秒,超时时间内部响应,就会执行熔断,进入fallback程序。由于Spring的懒加载机制,首次请求往往比较慢,可以通过配置Hystrix超时时间解决。
3、复杂案例
- 配置超时、并发、线程池、指定异常熔断忽略
/** * 复杂配置 */ @RequestMapping("/showInfo2") @HystrixCommand( fallbackMethod = "getDefaultInfo", commandProperties={ // 降级处理超时时间设置 @HystrixProperty(name = "execution.isolation.thread.timeoutInMilliseconds", value = "3000"), // 任意时间点允许的最高并发数。超过该设置值后,拒绝执行请求。 @HystrixProperty(name = "fallback.isolation.semaphore.maxConcurrentRequests", value = "1000"), }, // 配置执行的线城池 threadPoolProperties = { @HystrixProperty(name = "coreSize", value = "20"), @HystrixProperty(name = "maxQueueSize", value = "-1"), }, // 该异常不执行熔断,去执行该异常抛出的自己逻辑 ignoreExceptions = {ServiceException.class} ) public String showInfo2 (){ String value = "" ; // 测试配置异常不熔断 // 响应:{"code":500,"msg":"运行异常"} if (value.equals("")){ throw new ServiceException("运行异常") ; } // 该异常被熔断 // if (value.equals("")){ // throw new RuntimeException("抛出错误") ; // } return restTemplate.getForObject(server_name+"/getInfo",String.class) ; }
4、启动类注解
- @EnableHystrix
三、基于Feign服务熔断
1、Jar包说明
通过观察Fegin依赖的JAR可知,Fegin的Jar下包含Hystrix需要的Jar包,这里不用再次导入依赖。
2、熔断配置
Feign用接口实现的声明式Rest请求,所以配置也就在接口上面了。
1)、接口代码
@FeignClient(value = "NODE02-PROVIDER",fallback = FallbackService.class) public interface GetAuthorService { @RequestMapping(value = "/getAuthorInfo/{authorId}",method = RequestMethod.GET) String getAuthorInfo (@PathVariable("authorId") String authorId) ; }
2)、熔断执行代码
@Component public class FallbackService implements GetAuthorService { @Override public String getAuthorInfo(String authorId) { return "服务被熔断"+authorId; } }
3)、配置文件
- 开启熔断功能
feign: hystrix: enabled: true
3、服务类注解
由于上面的接口和熔断代码是在不同的Jar模块中,所以要在启动类@SpringBootApplication注解中扫描,如下。
@SpringBootApplication(scanBasePackages = {"cloud.node02.consume","cloud.block.code.service"}) @EnableEurekaClient // 本服务启动后会自动注册进eureka服务中 @EnableDiscoveryClient // 因为包名路径不同,需要加basePackages属性 @EnableFeignClients(basePackages={"cloud.block.code.service"}) public class Application_8002 { public static void main(String[] args) { SpringApplication.run(Application_8002.class,args) ; } }
四、源代码说明
GitHub地址:知了一笑 https://github.com/cicadasmile/spring-cloud-base 码云地址:知了一笑 https://gitee.com/cicadasmile/spring-cloud-base
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
全新角度剖析--iOS面试
一:面试题注意事项 (面试官角度) 我们很多iOS面试官在招聘的时候,很多都是直接在网上找一份iOS面试题就开始面试了!(偷懒)而我觉得这是一个很错误的做法。网上很多面试题的确不错,但是这样招聘过来的iOS开发人员不一定是非常优秀的,可能是背的面试题,也可能是贵公司的面试题泄漏,导致iOS求职者表现非常好! 1:面试题可以网上获取,但是我希望面试官认真对待,希望能够结合你们的公司实际开发,落地到面试题 (这样也就避免人家吐槽,面试造,开发拧) 2:面试题可以适当变动。根据求职者的简历情况,来变动面试题!有的简历不错的,可以适当调难一些。刚好在你的招聘及格线的求职者可以适当降低要求(毕竟要去不一样,后面薪资以及培养方向也会不一样) 3:根据贵公司的状况也考虑:要不要笔试!笔试无好坏,只是一轮刷选,能够帮你适当刷掉一部分不符合你要求的iOS开发人员!但是贵公司招聘情况很不理想,我觉得可以反思:是不是笔试太难,笔试题目过多... 二:面试流程 (面试官角度) 个人比较反感的是:招聘岗位很少,却叫去很多面试者面试!这个是一种比较严重不尊重求职的一种行为!其实也是对你的一种损失联系过多面试者来面...
- 下一篇
阿里巴巴集团副总裁余鹏武:边缘计算是城市计算,阿里云是城市计算的构建者
“边缘计算是基于场景的城市计算。随着5G的到来,首先会变化的是各行业的应用架构,从硬件、芯片、网络、中间件到应用服务,所有的技术都要向边缘演进,而阿里云就是城市计算背后的构建者。”在2019云栖大会首日的5G边缘计算分论坛上,阿里巴巴集团副总裁余鹏武发表《开拓新一代IT基础设施及应用创新》主题演讲,分享边缘计算的技术布局和未来应用。 余鹏武发表主题演讲 余鹏武表示,在5G环境下,无线网络的接入能力进一步跃升,数据的生产消费方式由集中生产、分散消费转变为分散生产、泛在消费,这意味着技术上需要进行应用的重构和产业的协同。目前所定义的5G三大应用场景eMBB、mMTC、URLLC,都是面向城市各领域的智能应用场景,其中有80%的数据和计算将会发生在边缘。阿里云所理解的边缘计算并不是为了计算而计算,而是为了承载更多新型的5G应用场景落地,它是
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS关闭SELinux安全模块
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- CentOS7安装Docker,走上虚拟化容器引擎之路
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- CentOS8编译安装MySQL8.0.19
- CentOS7,8上快速安装Gitea,搭建Git服务器
- Hadoop3单机部署,实现最简伪集群