Hystrix的执行流程和原理

1.构建一个HystrixCommand或者HystrixObservableCommand对象,将请求包装到Command对象中。

// 创建HystrixCommand对象

HystrixCommand command = new HystrixCommand(arg1, arg2);

// 创建HystrixObservableCommand

HystrixObservableCommand command = new HystrixObservableCommand(arg1, arg2);

2.执行命令。

// 调用后直接block住,属于同步调用,直到依赖服务返回单条结果,或者抛出异常,此方法(只适用于HystrixCommand)

K value = command.execute();

// 返回一个Future,属于异步调用,可以通过Future.get()获取单条结果,此方法(只适用于HystrixCommand)

Future fValue = command.queue();

// 订阅一个Observable对象,Observable代表的是依赖服务返回的结果,获取到一个那个代表结果的Observable对象的拷贝对象

Observable ohValue = command.observe();

// 返回一个Observable对象,如果我们订阅这个对象,就会执行command并且获取返回结果

Observable ocValue = command.toObservable();

3.判断当前请求是否有缓存,如果在缓存中就直接返回缓存的内容。

如果此命令启用了请求缓存,并且对请求的响应在缓存中可用,则该缓存的响应将以Observable的形式立即返回。

4.判断熔断器是否打开,如果开启,则跳到第8步。

判断断路器是否处于打开的状态,如果是打开状态,那么Hystrix就不再会去执行命令,直接跳到第 8 步,获取 fallback 方法,执行 fallback 逻辑。

5.判断线程池/队列/信号量是否已满,如果已满,则跳到第8步。

判断command对应的线程池/队列/信号量是否已满,如果已经满了,那么Hystrix就不再会去执行命令,直接跳到第 8 步,获取 fallback 方法,执行 fallback 逻辑。

6.执行HystrixObservableCommand.construct()/HystrixCommand.run(),如果执行失败或超时,跳到第8步;否则,跳到第9步;

调用HystrixObservableCommand.construct()或HystrixCommand.run()来实际执行这个command。

// 返回一个单条结果,或者抛出一个异常

HystrixCommand.run()

// 返回一个Observable对象,可以获取多条结果

HystrixObservableCommand.construct()

如果执行失败或超时,那么command所在的线程就会抛出异常,直接跳到第 8 步,获取 fallback 方法,执行 fallback 逻辑。

7.统计熔断器监控指标。

Hystrix向断路器报告成功,失败,拒绝和超时,断路器保持滚动的一组计算统计信息的计数器。

它使用这些统计信息来确定电路何时应“跳闸”,在此点它会将随后的所有请求短路,直到经过恢复期为止,在此之后,在首先检查某些运行状况检查之后,它将再次闭合电路。

8.走Fallback备用逻辑。

Hystrix在以下几种情况下会走降级逻辑:

1.执行construct()或run()抛出异常

2.熔断器打开导致命令短路

3.命令的线程池和队列或信号量的容量超额,命令被拒绝

4.命令执行超时

降级回退方式:

1.Fail Fast 快速失败:快速失败是最普通的命令执行方法,命令没有重写降级逻辑。 如果命令执行发生任何类型的故障,它将直接抛出异常。

2.Fail Silent 无声失败:指在降级方法中通过返回null,空Map,空List或其他类似的响应来完成。

3.Fallback: Static 返回默认值:指在降级方法中返回静态默认值。 这不会导致服务以“无声失败”的方式被删除,而是导致默认行为发生。

4.Fallback: Stubbed 自己组装一个值返回:当命令返回一个包含多个字段的复合对象时,适合以Stubbed 的方式回退。

5.Fallback: Cache via Network 利用远程缓存:有时,如果调用依赖服务失败,可以从缓存服务(如redis)中查询旧数据版本。由于又会发起远程调用,所以建议重新封装一个Command,使用不同的ThreadPoolKey,与主线程池进行隔离。

6.Primary + Secondary with Fallback 主次方式回退:有时系统具有两种行为- 主要和次要,或主要和故障转移。主要和次要逻辑涉及到不同的网络调用和业务逻辑,所以需要将主次逻辑封装在不同的Command中,使用线程池进行隔离。为了实现主从逻辑切换,可以将主次command封装在外观HystrixCommand的run方法中,并结合配置中心设置的开关切换主从逻辑。由于主次逻辑都是经过线程池隔离的HystrixCommand,因此外观HystrixCommand可以使用信号量隔离,而没有必要使用线程池隔离引入不必要的开销。

9.返回成功的响应。

返回结果。

熔断器工作原理

(图来源:https://github.com/Netflix/Hystrix/wiki/How-it-Works

说明:

第一步,调用allowRequest()判断是否允许将请求提交到线程池

1.如果熔断器强制打开,circuitBreaker.forceOpen为true,不允许放行,返回。

2.如果熔断器强制关闭,circuitBreaker.forceClosed为true,允许放行。此外不必关注熔断器实际状态,也就是说熔断器仍然会维护统计数据和开关状态,只是不生效而已。

第二步,调用isOpen()判断熔断器开关是否打开

最后的内容

在开头跟大家分享的时候我就说,面试我是没有做好准备的,全靠平时的积累,确实有点临时抱佛脚了,以至于我自己还是挺懊恼的。(准备好了或许可以拿个40k,没做准备只有30k+,你们懂那种感觉吗)

如何准备面试?

1、前期铺垫(技术沉积)

程序员面试其实是对于技术的一次摸底考试,你的技术牛逼,那你就是大爷。大厂对于技术的要求主要体现在:基础,原理,深入研究源码,广度,实战五个方面,也只有将原理理论结合实战才能把技术点吃透。

下面是我会看的一些资料笔记,希望能帮助大家由浅入深,由点到面的学习Java,应对大厂面试官的灵魂追问

这部分内容过多,小编只贴出部分内容展示给大家了,见谅见谅!

  • Java程序员必看《Java开发核心笔记(华山版)》

  • Redis学习笔记

  • Java并发编程学习笔记

四部分,详细拆分并发编程——并发编程+模式篇+应用篇+原理篇

  • Java程序员必看书籍《深入理解 ava虚拟机第3版》(pdf版)

  • 大厂面试必问——数据结构与算法汇集笔记

其他像Spring,SpringBoot,SpringCloud,SpringCloudAlibaba,Dubbo,Zookeeper,Kafka,RocketMQ,RabbitMQ,Netty,MySQL,Docker,K8s等等我都整理好,这里就不一一展示了。

2、狂刷面试题

技术主要是体现在平时的积累实用,面试前准备两个月的时间再好好复习一遍,紧接着就可以刷面试题了,下面这些面试题都是小编精心整理的,贴给大家看看。

①大厂高频45道笔试题(智商题)

②BAT大厂面试总结(部分内容截图)

③面试总结

![](https://upload-images.jianshu.io/upload_images/22932333-7f1e3e86b557d979?imageMogr2/auto-orient/st

必看视频!获取2024年最新Java开发全套学习资料 备注Java

rip%7CimageView2/2/w/1240)

3、结合实际,修改简历

程序员的简历一定要多下一些功夫,尤其是对一些字眼要再三斟酌,如“精通、熟悉、了解”这三者的区别一定要区分清楚,否则就是在给自己挖坑了。当然不会包装,我可以将我的简历给你参考参考,如果还不够,那下面这些简历模板任你挑选:

以上分享,希望大家可以在金三银四跳槽季找到一份好工作,但千万也记住,技术一定是平时工作种累计或者自学(或报班跟着老师学)通过实战累计的,千万不要临时抱佛脚。

另外,面试中遇到不会的问题不妨尝试讲讲自己的思路,因为有些问题不是考察我们的编程能力,而是逻辑思维表达能力;最后平时要进行自我分析与评价,做好职业规划,不断摸索,提高自己的编程能力和抽象思维能力。
在给自己挖坑了。当然不会包装,我可以将我的简历给你参考参考,如果还不够,那下面这些简历模板任你挑选:

[外链图片转存中…(img-K5cFF9wf-1716443417437)]

以上分享,希望大家可以在金三银四跳槽季找到一份好工作,但千万也记住,技术一定是平时工作种累计或者自学(或报班跟着老师学)通过实战累计的,千万不要临时抱佛脚。

另外,面试中遇到不会的问题不妨尝试讲讲自己的思路,因为有些问题不是考察我们的编程能力,而是逻辑思维表达能力;最后平时要进行自我分析与评价,做好职业规划,不断摸索,提高自己的编程能力和抽象思维能力。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值