当对同一资源发出多个请求时,Chrome会停止?

flu*_*ggo 41 google-chrome long-polling google-chrome-devtools

我正在尝试第一次实现长轮询,并且我正在使用XMLHttpRequest对象来执行它.到目前为止,我已经成功地在Firefox和Internet Explorer 11中获取了活动,但Chrome奇怪的是这次奇怪的是.

我可以加载一个页面,它运行得很好.它立即发出请求并开始处理和显示事件.如果我在第二个选项卡中打开页面,其中一个页面开始看到接收事件的延迟.在开发工具窗口中,我看到了这种时序的多个请求:

截图

"停滞"将持续长达20秒.它不会发生在每个请求上,但通常会连续发生在多个请求中,并且会出现在一个选项卡中.

起初我认为这是我的服务器的问题,但后来我打开了两个IE选项卡和两个Firefox选项卡,它们都连接并接收相同的事件而不会停止.只有Chrome遇到这种麻烦.

我认为这可能是我正在制作或提供请求的方式的问题.作为参考,请求标头如下所示:

Connection: keep-alive
Last-Event-Id: 530
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/39.0.2171.71 Safari/537.36
Accept: */*
DNT: 1
Accept-Encoding: gzip, deflate, sdch
Accept-Language: en-US,en;q=0.8
Run Code Online (Sandbox Code Playgroud)

响应如下:

HTTP/1.1 200 OK
Cache-Control: no-cache
Transfer-Encoding: chunked
Content-Type: text/event-stream
Expires: Tue, 16 Dec 2014 21:00:40 GMT
Server: Microsoft-HTTPAPI/2.0
Date: Tue, 16 Dec 2014 21:00:40 GMT
Connection: close
Run Code Online (Sandbox Code Playgroud)

尽管涉及到标题,但我没有使用浏览器的原生EventSource,而是使用polyfill来设置其他标题.polyfill正在使用XMLHttpRequest,但在我看来,无论请求是如何进行的,它都不应该停顿20秒.

什么可能导致Chrome像这样失速?

编辑: Chrome的chrome:// net-internals /#events页面显示涉及超时错误:

t=33627 [st=    5]      HTTP_CACHE_ADD_TO_ENTRY  [dt=20001]
                --> net_error = -409 (ERR_CACHE_LOCK_TIMEOUT)
Run Code Online (Sandbox Code Playgroud)

错误消息是指六个月前添加到Chrome的补丁(https://codereview.chromium.org/345643003),当多次请求同一资源时,该补丁实现了20秒的超时.实际上,补丁尝试修复的错误之一(错误号46104)指的是类似的情况,补丁意味着减少等待的时间.

这里的答案(或解决方法)可能只是让请求看起来不同,尽管Chrome可能会尊重我设置的"无缓存"标题.

flu*_*ggo 35

是的,此行为是由于Chrome锁定缓存并等待再次请求相同资源之前查看一个请求的结果.答案是找到一种使请求唯一的方法.我在查询字符串中添加了一个随机数,现在一切正常.

为了将来参考,这是Chrome 39.0.2171.95.

编辑:从这个答案,我已经明白"Cache-Control:no-cache"并不能达到我的想象.尽管名称如此,但可以缓存此标头的响应.我没有尝试,但我想知道是否使用"Cache-Control:no-store",这确实可以防止缓存,可以解决问题.

  • `Cache-Control:no-store`为我工作!非常有帮助的好答案,谢谢:D (3认同)
  • 我故意在服务器中设置了10秒的“睡眠”,发现如果我同时刷新2个具有相同url的chrome窗口,第一个需要10秒,第二个需要20秒。我可以从服务器日志中看到该 chrome 在第一个请求完成之前不会发送第二个请求,尽管它在第二个窗口中在整个 20 秒内显示状态为“待处理”。这与 HTTP 标头无关。如果 URL 不同或使用 Firefox,则不会发生这种情况。 (3认同)
  • 我遇到了这个问题,"Cache-Control:no-cache,no-store"对我有用.十分感谢! (2认同)
  • 接受的答案实际上不再有效。添加缓存控制不允许在较新的 chrome 版本中并行请求(我在版本 100 中检查过) (2认同)