Hystrix 源码解读,java初级工程师面试题掘金

@EnableCircuitBreaker 这注解也能开启Hystrix的相关功能

复制代码

image.png

image.png

其中读取spring.factories哪个文件的入口在此 org.springframework.cloud.commons.util.SpringFactoryImportSelector#selectImports

public String[] selectImports(AnnotationMetadata metadata) {

if (!isEnabled()) {

return new String[0];

}

AnnotationAttributes attributes = AnnotationAttributes.fromMap(

metadata.getAnnotationAttributes(this.annotationClass.getName(), true));

Assert.notNull(attributes, "No " + getSimpleName() + " attributes found. Is "

  • metadata.getClassName() + " annotated with @" + getSimpleName() + “?”);

// 因为是EnableCircuitBreaker这个注解读取的是META-INF/spring.factories 中org.springframework.cloud.netflix.hystrix.HystrixCircuitBreakerConfiguration 这个配置

List factories = new ArrayList<>(new LinkedHashSet<>(SpringFactoriesLoader

.loadFactoryNames(this.annotationClass, this.beanClassLoader)));

if (factories.isEmpty() && !hasDefaultFactory()) {

throw new IllegalStateException(“Annotation @” + getSimpleName()

  • " found, but there are no implementations. Did you forget to include a starter?");

}

if (factories.size() > 1) {

// there should only ever be one DiscoveryClient, but there might be more than

// one factory

log.warn("More than one implementation " + “of @” + getSimpleName()

  • " (now relying on @Conditionals to pick one): " + factories);

}

return factories.toArray(new String[factories.size()]);

}

复制代码

image.png

现在知道对应配置是怎么自动读取的吧!

相关源码分析


image.png

image.png

核心逻辑com.netflix.hystrix.contrib.javanica.aop.aspectj.HystrixCommandAspect#methodsAnnotatedWithHystrixCommand

@Around(“hystrixCommandAnnotationPointcut() || hystrixCollapserAnnotationPointcut()”)

public Object methodsAnnotatedWithHystrixCommand(final ProceedingJoinPoint joinPoint) throws Throwable {

Method method = getMethodFromTarget(joinPoint);

Validate.notNull(method, “failed to get method from joinPoint: %s”, joinPoint);

if (method.isAnnotationPresent(HystrixCommand.class) && method.isAnnotationPresent(HystrixCollapser.class)) {

throw new IllegalStateException("method cannot be annotated with HystrixCommand and HystrixCollapser " +

“annotations at the same time”);

}

MetaHolderFactory metaHolderFactory = META_HOLDER_FACTORY_MAP.get(HystrixPointcutType.of(method));

MetaHolder metaHolder = metaHolderFactory.create(joinPoint);

HystrixInvokable invokable = HystrixCommandFactory.getInstance().create(metaHolder);

ExecutionType executionType = metaHolder.isCollapserAnnotationPresent() ?

metaHolder.getCollapserExecutionType() : metaHolder.getExecutionType();

Object result;

try {

if (!metaHolder.isObservable()) {

result = CommandExecutor.execute(invokable, executionType, metaHolder);

} else {

result = executeObservable(invokable, executionType, metaHolder);

}

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024b (备注Java)
img

最后总结我的面试经验

2021年的金三银四一眨眼就到了,对于很多人来说是跳槽的好机会,大厂面试远没有我们想的那么困难,摆好心态,做好准备,你也可以的。

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

BAT面试经验

实战系列:Spring全家桶+Redis等

其他相关的电子书:源码+调优

面试真题:


存中…(img-LGFm8uG7-1712078483958)]

其他相关的电子书:源码+调优

[外链图片转存中…(img-vjo5N5i6-1712078483959)]

面试真题:

[外链图片转存中…(img-yGEQ7077-1712078483959)]

[外链图片转存中…(img-B1eTWVSQ-1712078483959)]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值