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)]
以上分享,希望大家可以在金三银四跳槽季找到一份好工作,但千万也记住,技术一定是平时工作种累计或者自学(或报班跟着老师学)通过实战累计的,千万不要临时抱佛脚。
另外,面试中遇到不会的问题不妨尝试讲讲自己的思路,因为有些问题不是考察我们的编程能力,而是逻辑思维表达能力;最后平时要进行自我分析与评价,做好职业规划,不断摸索,提高自己的编程能力和抽象思维能力。