行业资讯 2025年08月6日
0 收藏 0 点赞 284 浏览 919 个字
摘要 :

接着我们上一小节的内容,我们在cloud-provider-payment8001和cloud-provider-payment8002的PaymentController中新增一个演示超时的方法如下: @GetMapping(value = &qu……

接着我们上一小节的内容,我们在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

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

微信扫一扫

支付宝扫一扫

版权: 转载请注明出处:https://www.zuozi.net/7904.html

管理员

相关推荐
2025-08-06

文章目录 一、Reader 接口概述 1.1 什么是 Reader 接口? 1.2 Reader 与 InputStream 的区别 1.3 …

988
2025-08-06

文章目录 一、事件溯源 (一)核心概念 (二)Kafka与Golang的优势 (三)完整代码实现 二、命令…

465
2025-08-06

文章目录 一、证明GC期间执行native函数的线程仍在运行 二、native线程操作Java对象的影响及处理方…

348
2025-08-06

文章目录 一、事务基础概念 二、MyBatis事务管理机制 (一)JDBC原生事务管理(JdbcTransaction)…

456
2025-08-06

文章目录 一、SnowFlake算法核心原理 二、SnowFlake算法工作流程详解 三、SnowFlake算法的Java代码…

517
2025-08-06

文章目录 一、本地Jar包的加载操作 二、本地Class的加载方法 三、远程Jar包的加载方式 你知道Groo…

832
发表评论
暂无评论

还没有评论呢,快来抢沙发~

助力内容变现

将您的收入提升到一个新的水平

点击联系客服

在线时间:08:00-23:00

客服QQ

122325244

客服电话

400-888-8888

客服邮箱

122325244@qq.com

扫描二维码

关注微信客服号