• 追踪代码我们可以看到是 client 是从 HttpHeader 中读取 Keep-Alive: timeout=xx,如果没有读到就认为永不超时。
  • 而 Nginx 配置的第二个参数就是这个,因此只要服务端将 keepalive_timeout 30s;改为 keepalive_timeout 30s 29s;即可,这里少 1s 为了防止网络延时造成的并发问题。
  • 客户端方案

    如果服务端不方便修改,那么第二方案是客户端这边修改,比较麻烦。

  • 首先保证用最新的 httpClient
  • 其次有三种方法:
  • 对于 jest 这类有定时 closeIdleConnection 的,可以将调度时间调整为 keep alive 时间的一半以下以保证超时前回收
  • 根据 keep Alive 时间,调整 validateAfterInactivity 小于 keepAlive Time`,但这种方法依旧不能避免同时关闭。
  • 补偿方案,使用 Retry 重新发送尝试一次。 HttpClient 默认是打开自动重试的,不要调用 disableAutomaticRetries 即可
  • 推荐的方案

  • 客户端使用短连接,比如换成 UrlConnection
  • HttpClient 连接保活时间调的小于 15s 或者将 nginx keepalive_timeout 调的大于 30s;
  • 不用 PoolingHttpClientConnectionManager
  • 出错后重试, HttpClient RetryHandler
  • JDK11已经带了 HttpClinet ,这不吸引人么?
  • 《注定成为最穷的程序员…… @待业科技(大连)有限公司
    粉丝