Hystrix(熔断)
动态的修改熔断配置
背景:hystrix 熔断过程问题 和日志问题 需要熔断的场景 动态改变我们的配置参数 智能化
其实本身的HystrixCommand 注解也是通过切面配置的,我们这边可以通过自定义注解动态加入
@Aspect
@Component
public class MyHystrixCommandAspect {
public static Boolean timeoutInMilliseconds = Boolean.FALSE;
@Pointcut("@annotation(com.netflix.hystrix.contrib.javanica.annotation.HystrixCommand)")
public void hystrixCommandAnnotationPointcut() {
}
@Around("hystrixCommandAnnotationPointcut()")
public Object methodsAnnotatedWithHystrixCommand(final ProceedingJoinPoint joinPoint) throws Throwable {
if (timeoutInMilliseconds) {
System.out.print("%%%%%%%%%%%%%%%%%%%%%");
Method method = null; //getMethodFromTarget(joinPoint);
HystrixCommand hystrixCommand = method.getAnnotation(HystrixCommand.class);
HystrixProperty[] hystrixProperties = hystrixCommand.commandProperties();
for (HystrixProperty hystrixProperty : hystrixProperties) {
if ("execution.isolation.thread.timeoutInMilliseconds".equals(hystrixProperty.name())) {
InvocationHandler h = Proxy.getInvocationHandler(hystrixProperty);
Field hField = h.getClass().getDeclaredField("memberValues");
hField.setAccessible(true);
Map memberValues = (Map) hField.get(h);
memberValues.put("value", "6000");
}
}
}
Object obj = joinPoint.proceed();
return obj;
}
}
拦截器选择 HystrixCommand 注解然后获取注解里面的属性如果不存在就获取数据库的值修改