feign默认集成了hystrix,那么问题来了,如何像hystrix command那样设置每一个方法的hystrix属性呢。java
@FeignClient("product") public interface RemoteProductService { @RequestMapping(method = RequestMethod.GET,value = "/product/{productId}") public Product getProduct(@PathVariable(value = "productId") int productId); }
spring-cloud-netflix-core-1.2.6.RELEASE-sources.jar!/org/springframework/cloud/netflix/feign/FeignClientsConfiguration.javaspring
@Configuration @ConditionalOnClass({ HystrixCommand.class, HystrixFeign.class }) protected static class HystrixFeignConfiguration { @Bean @Scope("prototype") @ConditionalOnMissingBean @ConditionalOnProperty(name = "feign.hystrix.enabled", matchIfMissing = true) public Feign.Builder feignHystrixBuilder() { return HystrixFeign.builder(); } }
feign-hystrix-9.3.1-sources.jar!/feign/hystrix/HystrixFeign.java微信
private SetterFactory setterFactory = new SetterFactory.Default();
feign-hystrix-9.3.1-sources.jar!/feign/hystrix/SetterFactory.javaapp
public interface SetterFactory { /** * Returns a hystrix setter appropriate for the given target and method */ HystrixCommand.Setter create(Target<?> target, Method method); /** * Default behavior is to derive the group key from {@link Target#name()} and the command key from * {@link Feign#configKey(Class, Method)}. */ final class Default implements SetterFactory { @Override public HystrixCommand.Setter create(Target<?> target, Method method) { String groupKey = target.name(); String commandKey = Feign.configKey(target.type(), method); return HystrixCommand.Setter .withGroupKey(HystrixCommandGroupKey.Factory.asKey(groupKey)) .andCommandKey(HystrixCommandKey.Factory.asKey(commandKey)); } } }
groupKey,这里为product,即@FeignClient("product")中的值。ide
feign-core-9.3.1-sources.jar!/feign/Feign.javaui
public static String configKey(Class targetType, Method method) { StringBuilder builder = new StringBuilder(); builder.append(targetType.getSimpleName()); builder.append('#').append(method.getName()).append('('); for (Type param : method.getGenericParameterTypes()) { param = Types.resolve(targetType, targetType, param); builder.append(Types.getRawType(param).getSimpleName()).append(','); } if (method.getParameterTypes().length > 0) { builder.deleteCharAt(builder.length() - 1); } return builder.append(')').toString(); }
commandKey的构造,这里组装了类、方法名、参数,好比本文的实例,commandKey=RemoteProductService#getProduct(int)spa
hystrix: command: "RemoteProductService#getProduct(int)": execution: isolation: thread: timeoutInMilliseconds: 500
@Bean public Feign.Builder feignHystrixBuilder() { return HystrixFeign.builder().setterFactory(new SetterFactory() { @Override public HystrixCommand.Setter create(Target<?> target, Method method) { return HystrixCommand.Setter .withGroupKey(HystrixCommandGroupKey.Factory.asKey(RemoteProductService.class.getSimpleName()))// 控制 RemoteProductService 下,全部方法的Hystrix Configuration .andCommandPropertiesDefaults( HystrixCommandProperties.Setter().withExecutionTimeoutInMilliseconds(10000) // 超时配置 ); } }); }
论灵活程度,仍是配置文件灵活一点,惟一的工做量就是根据规则构造commandKey,而后就能够进行相关配置了。prototype
想获取最新内容,请关注微信公众号code