1. RestTemplate

HttpClient 内部有三个超时时间设置:连接池获取可用连接超时,连接超时,读取数据超时:

1.1. ConnectionRequestTimeout

从连接池中获取可用连接超时时间,设置从 connect Manager 获取 Connection 超时时间,单位毫秒

HttpClient 中的要用连接时尝试从连接池中获取,若是在等待了一定的时间后还没有获取到可用连接(比如连接池中没有空闲连接了)则会抛出获取连接超时异常。

1.2. connectionTimeout

连接目标超时 connectionTimeout,单位毫秒。

指的是连接目标 url 的连接超时时间,即客服端发送请求到与目标 url 建立起连接的最大时间。如果在该时间范围内还没有建立起连接,则就抛出 connectionTimeOut 异常。

如测试的时候,将 url 改为一个不存在的 url:“http://test.com” ,超时时间 3000ms 过后,系统报出异常:   org.apache.commons.httpclient.ConnectTimeoutException:The host did not accept the connection within timeout of 3000 ms

1.2.1. 默认值 -1:

RestTemplate 默认是使用 SimpleClientHttpRequestFactory,内部是调用 jdk 的 HttpConnection,默认超时为 -1

1.2.2. 生产设置

建议:
ConnectTimeout 大小视网络环境
ReadTimeout 大小视应用程序操作,适当大一点。
ConnectionRequestTimeout 不宜过长。

1.3. socketTimeout

等待响应超时(读取数据超时)socketTimeout ,单位毫秒。

连接上一个 url 后,获取 response 的返回等待时间 ,即在与目标 url 建立连接后,等待放回 response 的最大时间,在规定时间内没有返回响应的话就抛出 SocketTimeout。

测试时,将 socketTimeout 设置很短,会报等待响应超时。

1.4. 超时积压案例

https://www.jb51.net/article/235219.htm

image.png

https://leokongwq.github.io/2018/11/21/springboot-resttempate-timout.html

2. OpenFeign

%%
▶2.🏡⭐️◼️【🌈费曼无敌🌈⭐️第一步⭐️】◼️⭐️-point-20230416-2153%%
❕ ^ptr2sl

2.1. 配置全局

1
2
3
4
5
6
7
8
feign:
client:
config:
default:
#建立连接所用的时间,适用于网络状况正常的情况下,两端连接所需要的时间,
ConnectTimeOut: 5000
#指建立连接后从服务端读取到可用资源所用的时间,默认为1s
ReadTimeOut: 5000

2.2. 配置指定服务

1
2
3
4
5
6
7
feign:
client:
config:
服务id:
connectTimeout: 1000
readTimeout: 2000
retryer: feign.Retryer.Default # 重试

2.3. 配置指定 contextId

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
feign:
client:
config:
default:
# 日志级别
loggerLevel: full
# 超时设置
connectTimeout: 1500
readTimeout: 1500
payment-core:
connectTimeout: 5000
readTimeout: 5000
# 断路器
circuitbreaker:
enabled: true
1
2
3
4
5
@FeignClient(name = "payment-service", contextId = "payment-core",  path = "/payment")
public interface PaymentFeign {
@PostMapping("/create")
PaymentVo create(@RequestBody @Validated PaymentDto paymentDto);
}

2.4. 同时配置 Ribbon 和 OpenFeign 的超时时间

时间小的配置生效

2.5. 使用避坑

https://www.modb.pro/db/103672

3. 实战经验

4. 参考与感谢