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",这确实可以防止缓存,可以解决问题.
| 归档时间: |
|
| 查看次数: |
31749 次 |
| 最近记录: |