Read timed out executing GET (读取执行GET超时)

在SpringCloud项目中,使用EMQ队列服务时遇到调用服务超时的问题。通常,调整 Ribbon 的请求处理与连接超时时间、Hystrix配置或启用重试机制能解决问题。如果服务端出错或请求方式不正确(如被调用方要求POST,实际发送GET),需相应调整。此外,检查环境资源如内存是否充足也是排查步骤之一。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

背景

springcloud 项目中使用了 emq 队列服务。
在测试时发现一个问题,就是项目会报此错

feign.RetryableException: Read timed out executing GET http://upm-service/upm/api/device/statusUpload

如图

这是调用服务超时

实际就是熔断器经过发送http请求尝试连接但是未成功返回了错误信息,导致报错。理论上我们可以修改 hystrix 的状态为关闭,或者关闭异常捕捉错误返回,

  1. 不过通常我们只需要修改 ribbon 的请求处理与请求连接的时间,修改位置在配置文件 application.properties (我这里是网关的配置文件)如下:
    如图
    当然相对 hystrix 的连接时间也要修改,不然无意义,如下:
    如图

  2. 如果此情况下依然报错,我们则可以尝试关闭 fegin 的二层调用对象 hystrix 如下:

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值