V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
NGINX
NGINX Trac
3rd Party Modules
Security Advisories
CHANGES
OpenResty
ngx_lua
Tengine
在线学习资源
NGINX 开发从入门到精通
NGINX Modules
ngx_echo
kokol
V2EX  ›  NGINX

nginx 的 cache file has too long header 问题

  •  
  •   kokol · 2020-10-20 23:41:22 +08:00 · 2872 次点击
    这是一个创建于 1523 天前的主题,其中的信息可能已经有所发展或是发生改变。
    有时在 nginx 的日志里会碰到如下的日志错误:

    cache file "/usr/local/openresty/nginx/cache/c/0c/1eb7633e809b8306294a2a7da39c80cc" has too long header

    一般什么情况下,才会出现这个错误,我的 proxy_buffer_size 这些设置都是用的默认值。

    google 搜索了一下,看到 nginx 的源代码里有如下的代码:
    https://github.com/phusion/nginx/blob/master/src/http/ngx_http_file_cache.c
    if (h->body_start > c->body_start) {
    ngx_log_error(NGX_LOG_CRIT, r->connection->log, 0,
    "cache file \"%s\" has too long header",
    c->file.name.data);
    return NGX_DECLINED;
    }

    http://hg.nginx.org/nginx/rev/6f97afc238de 这个网站也有相应的说明

    我自己也测试了一下,proxy_buffer_size 这些设置都是用的默认值,然后请求一个 2M 的文件,proxy_cache 的文件夹里也有缓存的文件,但是访问都是正常的,我还是无法复现这种错误,不知道什么情况下会出现这个错误
    2 条回复    2020-10-22 11:17:20 +08:00
    geekzu
        1
    geekzu  
       2020-10-21 09:58:29 +08:00
    之前遇到过,查了一圈应该是 cache 文件失效 /损坏导致,这种状态 nginx 会重新取源做新的 cache
    kokol
        2
    kokol  
    OP
       2020-10-22 11:17:20 +08:00
    @geekzu 谢谢,我用 ab 压测工具压测了下,有个上千并发的时候,就会有 cache file has too long header 的错误
    如果 nginx 响应的 body 比较大的时候,出现的概率也大。

    难道是在高并发情况下,nginx 从后端获取到文件之后,放入了一部分到缓存文件里,另一个请求过来发现文件不完整就重新去后端请求
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2608 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 19ms · UTC 10:52 · PVG 18:52 · LAX 02:52 · JFK 05:52
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.