时间:2021-05-20
我就废话不多说了,大家还是直接看代码吧~
/** * feign调用客户端 */@FeignClient(name = "user", url = "${user.url}", configuration = MyFeignDecoder.class)public interface UserClient { @GetMapping("/rest/user/get/detail/{loginName}") JSONObject getUserInfoByLoginName(@PathVariable(value = "loginName") String loginName);}import org.slf4j.Logger;import org.slf4j.LoggerFactory;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;import org.springframework.context.annotation.Primary;import org.springframework.context.annotation.Scope;import com.iflytek.icourt.exception.UnloginErrorException;import com.iflytek.icourt.secretary.constant.Constant;import com.netflix.hystrix.exception.HystrixBadRequestException;import feign.Request;import feign.Response;import feign.codec.Encoder;import feign.jackson.JacksonEncoder;/** * feign配置类 */@Configurationpublic class MyFeignDecoder implements feign.codec.ErrorDecoder{ public static Logger logger = LoggerFactory .getLogger(MyFeignDecoder.class); @Override public Exception decode(String methodKey, Response response) { logger.info("status:-------" + response.status()); return feign.FeignException.errorStatus(methodKey, response); } @Bean @Primary @Scope("prototype") public Encoder jacksonEncoder () { return new JacksonEncoder(); } @Bean Request.Options feignOptions() { return new Request.Options(2 * 1000, 120 * 1000); }}补充知识:feign调用问题\超时
1、项目结构 每个微服务是provider情况下有一个client模块(里面含有定义好的feignclient 接口) 专门打包出去给其他微服务消费
这样的话 其他需要调用的微服务只要把这个client jar包引入即可,
2、在其他微服务中 引入clientXX.jar 这时候有一个坑, 就是 @EnableFeignClients这个注解默认是只扫描项目启动application下的包 如果不同项目可能包路径不一致, 所以@EnableFeignClients得指定你的client.jar里面的路径 或者两个项目中 共同的顶级路径 例如com.XX.cloud 同一个公司内部 顶层包结构应该是一致的
3、feign调用超时 默认feign调用超时是1000毫秒的 有断点就肯定超时
需要加上以下配置
feign.hystrix.enabled=true#feign调用默认是1000毫秒=1秒 应该设置成更长时间1000 * 60 * 5 = 5分钟 add by six-visionhystrix.command.default.execution.isolation.thread.timeoutInMilliseconds=300000hystrix.command.default.circuitBreaker.sleepWindowInMilliseconds=300000hystrix.command.default.circuitBreaker.forceClosed=true#hystrix.command.default.execution.timeout.enabled=false#请求处理的超时时间 add by six-visionribbon.ReadTimeout=300000ribbon.SocketTimeout=300000#请求连接的超时时间 add by six-visionribbon.ConnectTimeout: 30000以上这篇feign客户端设置超时时间操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
概述在一条慢SQL导致购物车服务无法使用的解决方案一文中,提到了客户端调用购物车服务的时候,超时了。如果当时客户端没有设置超时时间的话,会在客户端中产生级联故障
概述SpringCloud中,客户端的负载均衡使用的是Ribbon,Ribbon的超时时间默认很短,需要进行调整。SpringCloud版本Edgware.SR
1:多客户端时,feign接口抽取到公共jar中,此时,客户端的启动类上需要对该jar中feign所在的包进行扫描,要在spring和feign中同时注册,否则
在之前的文章中,我们在Windows下玩过带有超时时间的,本文我们在linux下来玩。在某次面试中,还被遇到了这个问题,有意思。直接上客户端代码:#includ
一.增加超时的时间限制这里需要注意:set_time_limit只是设置你的PHP程序的超时时间,而不是file_get_contents函数读取URL的超时时