接着我们上一小节的内容,我们在cloud-provider-payment8001和cloud-provider-payment8002的PaymentController中新增一个演示超时的方法如下:
@GetMapping(value = "/payment/feign/timeout")
public String paymentTimeout(){
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
return serverPort;
}
然后再在cloud-consumer-feign-order80中的OrderFeignService和OrderFeignController添加如下代码:
[v_act]OrderFeignService[/v_act]
@GetMapping(value = "/payment/feign/timeout") public String paymentTimeout();
[v_act]OrderFeignController[/v_act]

程序员导航
优网导航旗下整合全网优质开发资源,一站式IT编程学习与工具大全网站
@GetMapping("/consumer/payment/feign/timeout")
public String paymentTimeout(){
return orderFeignService.paymentTimeout();
}
然后重启相关服务,去测试访问,发现出现超时报错情况,如下:

[v_act]原因:[/v_act]OpenFeign客户端默认只等待一秒钟, 但是服务端处理需要超过1秒钟,就会导致OpenFeign客户端不想等待了,直接返回报错。为了避免这样的情况,有时候我们需要设置OpenFeign客户端的超时控制。
[v_act]解决:[/v_act]我们在cloud-consumer-feign-order80的application.yml中添加如下的配置:
#设置feign客户端超时时间(openFeign默认支持ribbon) ribbon: #指的是建立连接后从服务器读取到可用资源所用的时间 ReadTimeout: 5000 #指的是建立连接所用的时间,适用F网络状况正常的情况下,两端连接所用的时间 ConnectTimeout: 5000
重启后,再次测试,发现正常访问。
© 版权声明
文章版权归作者所有,未经允许请勿转载。
相关文章
暂无评论...



