0

关于 HTTP keep-alive 如何在客户端处理请求超时?例如有一个流程:

  • 客户端发送Request1;
  • 客户端等待 1 分钟;
  • 客户端假设Request1失败,重新发送,即发送new Request2 = Request1;
  • 服务器响应 Response1(这是对 Request1 的响应);
  • 客户端假设这是对 Request2 的响应,但可以处理它,因为 Request1 = Request2;
  • 客户端发送Request3;
  • 服务器以 Response2 响应(这是对 Request2 的响应);
  • 客户端假定这是对 Request3 的响应,但未能处理它。

我在规范中找不到任何信息。它说明了如果连接被服务器关闭时如何重试,但没有说明请求花费太长时间才能继续的情况。

4

1 回答 1

0

我有使用 ASP.NET 的经验,但我不确定此范例是否用于所有 HTTP 管道。以下是我的理解:

  • 响应与请求相关联。在 C# 中,有一个HttpContext可以促进这一点。新请求来自一个单独的线程,该线程没有任何其他请求的安全上下文。
  • 当客户端发出请求时(例如,通过WebRequest),响应与该请求相关联。

因此Request1,在您的示例中永远不能与Request2. HTTP 请求标头中使用的keep-alive表示不应关闭底层 TCP 连接,以便可以将其重用于其他请求。据我了解,单个请求超时不会影响底层 TCP 连接;也就是说,即使 TCP 连接是共享的,请求-响应机制也照常工作。

于 2015-12-17T13:45:28.923 回答