AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 482875
Accepted
Julien
Julien
Asked: 2013-02-27 20:48:49 +0800 CST2013-02-27 20:48:49 +0800 CST 2013-02-27 20:48:49 +0800 CST

为什么 Nginx 删除分块内容的 Content-Length 标头?

  • 772

我使用 nginx 1.2.3 来代理脚本:

proxy_set_header Host $host;
proxy_pass http://127.0.0.1:8880;
proxy_buffering off;
proxy_read_timeout 300s;
gzip off;

脚本同时发送Transfer-encoding: chunked和Content-Length: 251:

HTTP/1.0 307 Temporary Redirect
Content-length: 251
Pragma: no-cache
Location: /...
Cache-control: no-cache
Transfer-encoding: chunked

我两者都需要,但 nginx 会自动删除Content-Length:

HTTP/1.1 302 Found
Server: nginx/1.2.3
Content-Type: application/json; charset=utf-8
Content-Length: 58
Connection: keep-alive
Location: /...

因此,客户端不会等待数据块被发送。这曾经与较早版本的 nginx 一起使用。

nginx
  • 5 5 个回答
  • 43838 Views

5 个回答

  • Voted
  1. Best Answer
    Lukas
    2013-03-11T07:59:10+08:002013-03-11T07:59:10+08:00

    不幸的是,我无法对 cnst 的帖子发表评论 - 所以我将在这里回答。

    该nginx_http_proxy模块默认与 HTTP/1.0 中的上游通信。这可以用指令改变proxy_http_version 1.1。

    这也可能是您的脚本返回 HTTP/1.0 答案的原因,尽管307此版本中不存在分块编码和状态代码。

    您也不应该将分块编码与重定向一起使用,因为这实际上没有意义。

    此外,nginx 似乎并没有将上游的块一个一个地传递给客户端,而是缓冲了上游的响应。标题Content-Length字段被忽略,因为它违反了定义。我不得不查看模块的源代码,因为所有这些似乎都没有记录。

    您可能想尝试nginx_tcp_proxy_module将分块内容代理为原始 TCP 数据:Github 上的模块


    更新(10.04.14)
    该nginx_http_proxy模块支持X-Accel-* headers,其中一个 ( X-Accel-Buffering: yes|no) 控制响应是否应该被缓冲。

    将此标头 ( X-Accel-Buffering: no) 添加到后端的响应将导致 nginx 直接将块传递给客户端。

    此标头允许在每个请求的基础上控制缓冲。

    该模块还有一个配置指令 proxy_buffering来启用或禁用响应缓冲(不缓冲意味着发送块将起作用)。

    此处记录了代理缓冲(基于标头和指令)。

    • 12
  2. Jo Liss
    2013-09-30T14:14:12+08:002013-09-30T14:14:12+08:00

    正如 Lukas 暗示的那样,HTTP 1.1 禁止Content-Length如果有一个Transfer-Encoding集合。

    引用http://www.ietf.org/rfc/rfc2616.txt:

       3.If a Content-Length header field (section 14.13) is present, its
         decimal value in OCTETs represents both the entity-length and the
         transfer-length. The Content-Length header field MUST NOT be sent
         if these two lengths are different (i.e., if a Transfer-Encoding
         header field is present). If a message is received with both a
         Transfer-Encoding header field and a Content-Length header field,
         the latter MUST be ignored.
    
    • 10
  3. cnst
    2013-03-06T13:07:04+08:002013-03-06T13:07:04+08:00

    您没有具体说明为什么您的脚本首先需要分块编码,尤其是对于重定向响应。

    我在这里看到了很多问题。

    • Transfer-Encoding: chunked是一项HTTP/1.1功能(您的脚本似乎在回复HTTP/1.0标题)

    • 没有307_HTTP/1.0

    • 的全部目的chunked是你不知道你Content-Length本来会是什么,所以,chunked用它来代替提供长度Content-Length,而长度是在响应正文中提供的,与实际内容混合在一起;脚本预先生成两个标头是没有意义的

    我个人并不熟悉chunked,但根据http://en.wikipedia.org/wiki/Chunked_transfer_encoding和https://www.rfc-editor.org/rfc/rfc2616#section-3.6 上的基本信息。 1,我猜测您的脚本对分块编码的整个处理可能是完全错误的。

    如果以上内容仍然没有涵盖它,并且实际上并非如此,那么也不清楚为什么应该为带有 a307或302http 状态代码的回复提供“奇怪”的编码。最近在 nginx 邮件列表中有一个类似的讨论,关于410 Gone其他错误页面总是被排除在gzip压缩之外,我认为这种观点在这里同样适用。( http://mailman.nginx.org/pipermail/nginx/2013-March/037890.html )

    • 3
  4. Buzut
    2014-09-10T21:30:06+08:002014-09-10T21:30:06+08:00

    我有同样的问题通过 html5 视频标签流式传输 mp4 文件。

    Safari 和 Firefox 表现正常,而 Chrome 在某些时候触发了 ERR_CONTENT_LENGTH_MISMATCH(但它让我在失败前观看了几分钟的视频)。

    关闭 mp4 文件的缓存控制后,问题没有重现。

    • 1
  5. Kelton Temby
    2019-12-16T14:56:24+08:002019-12-16T14:56:24+08:00

    分享我发布到 SO 的这个答案,以防它有帮助:https ://stackoverflow.com/questions/50499637/mp4-video-safari-cloudflare-nginx-rails-no-play/59348509#59348509

    由于未提供块,我在 mp4 播放方面遇到了类似的问题,并根据下面列出的 Apple 指南确认了该问题。我确认我正在下载整个文件,并且在下面的修复之后,只有第一个块。

    curl --range 0-99 http://example.com/test.mov -o /dev/null
    

    我通过更改 nginx.conf 中的 gzip 压缩设置来解决我的 Safari .mp4 播放问题,以删除.mp4文件的 gzip 压缩。

    这是 nginx 中的块以供参考。(注意:根据您的应用程序的配置方式,您可能需要将位置行更改为location ~ \.mp4$ {

    location ~ ^/(assets|system|videos)/  {
       expires max;
       add_header Cache-Control public;
       add_header ETag "";
       gzip on;
       gzip_http_version 1.1;
       gzip_vary on;
       gzip_comp_level 6;
       gzip_proxied any;
    
       # Reference configuration
       #gzip_types text/plain text/html text/css application/json application/javascript application/x-javascript text/javascript video/mp4 application/mp4 image/jpeg image/png image/svg+xml application/x-font-ttf application/x-font-truetype application/font-woff application/font-woff2 application/vnd.ms-fontobject;
    
       # Kelton trying to fix cloudflare by removing the mp4 settings
       gzip_types text/plain text/html text/css application/json application/javascript application/x-javascript text/javascript image/jpeg image/png image/svg+xml application/application/x-font-ttf application/x-font-truetype application/font-woff application/font-woff2 application/vnd.ms-fontobject;
    }
    

    Apple 文档参考链接:https ://developer.apple.com/library/archive/documentation/AppleApplications/Reference/SafariWebContent/CreatingVideoforSafarioniPhone/CreatingVideoforSafarioniPhone.html#//apple_ref/doc/uid/TP40006514-SW6

    • 0

相关问题

  • Gzip 与反向代理缓存

  • nginx 作为代理的行为

  • Nginx 学习资源 [关闭]

  • 提供 70,000 个静态文件 (jpg) 的最佳方式?

  • 在 Apache、LightTPD 和 Nginx Web 服务器上提供 PHP 5.x 应用程序的现状?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve