OpenFeign超时控制—SpringCloud(H版)微服务学习教程(23)

Java技术 潘老师 7个月前 (03-26) 596 ℃ (0) 扫码查看

接着我们上一小节的内容,我们在cloud-provider-payment8001cloud-provider-payment8002PaymentController中新增一个演示超时的方法如下:

@GetMapping(value = "/payment/feign/timeout")
public String  paymentTimeout(){
    try {
        Thread.sleep(3000);
    } catch (InterruptedException e) {
        e.printStackTrace();
    }
    return serverPort;
}

然后再在cloud-consumer-feign-order80中的OrderFeignServiceOrderFeignController添加如下代码:

OrderFeignService

@GetMapping(value = "/payment/feign/timeout")
public String paymentTimeout();
OrderFeignController
@GetMapping("/consumer/payment/feign/timeout")
public String paymentTimeout(){
    return orderFeignService.paymentTimeout();
}

然后重启相关服务,去测试访问,发现出现超时报错情况,如下:
OpenFeign超时控制—SpringCloud(H版)微服务学习教程(23)

原因:
OpenFeign客户端默认只等待一秒钟, 但是服务端处理需要超过1秒钟,就会导致OpenFeign客户端不想等待了,直接返回报错。为了避免这样的情况,有时候我们需要设置OpenFeign客户端的超时控制。
解决:
我们在cloud-consumer-feign-order80application.yml中添加如下的配置:

#设置feign客户端超时时间(openFeign默认支持ribbon)
ribbon:
  #指的是建立连接后从服务器读取到可用资源所用的时间
  ReadTimeout: 5000
  #指的是建立连接所用的时间,适用F网络状况正常的情况下,两端连接所用的时间
  ConnectTimeout: 5000

重启后,再次测试,发现正常访问。


版权声明:本站所有文章,如无特殊说明,均为本站原创。全部下载资源版权归原作者所有。任何个人或组织,若未征得本站同意,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。若需转载请注明文章来源。
本文链接:OpenFeign超时控制—SpringCloud(H版)微服务学习教程(23)
喜欢 (0)
请潘老师喝杯Coffee吧!】
分享 (0)
用户头像
发表我的评论
取消评论
表情 贴图 签到 代码

Hi,您需要填写昵称和邮箱!

  • 昵称【必填】
  • 邮箱【必填】
  • 网址【可选】

您也可以 微信登录 来发表评论!