答案是proxy_buffer_size过小导致Nginx无法容纳后端响应头而触发502错误;需先通过错误日志和curl -v验证header实际大小,再将proxy_buffer_size设为略大于最大单行header的值(如128k),并协同配置proxy_buffers和proxy_busy_buffers_size。
502 错误里有一类很典型:后端服务明明运行正常,Nginx 却突然返回 502,错误日志里清清楚楚写着 “upstream sent too big header while reading response header from upstream”。这说明问题出在响应头(Header)过大,而 proxy_buffer_size 不够用——它专管 Header,和 JSON 大小、文件体积这些响应体(Body)完全无关。
别凭感觉调参数,先看证据:
grep "too big header" /var/log/nginx/error.log,有就坐实了curl -v http://your-api/ 2>&1 | grep '^ 统计原始响应头总字节数(注意:<code>-I 会截断部分头,不准)Set-Cookie、Authorization、X-Trace-ID、Link 这几类容易膨胀的头,单条超 4KB 很常见这个值不是越大越好,也不是所有头加起来的总和,而是要 ≥ 后端返回的最长单行响应头长度(比如一条 JWT Cookie 可能就占 10KB):
proxy_buffer_size 16k
proxy_buffer_size 32k
64k,但不建议盲目设成 1m(浪费内存,还可能被利用)location 或 server 块里,且在 proxy_pass 之前生效proxy_buffer_size 不是单打独斗的,它和另外两个参数协同工作:
proxy_buffers 8 32k:分配 8 个缓冲区,每个 32KB,专存响应体(Body)proxy_busy_buffers_size 64k:划出最多 64KB 边收边发给客户端;该值必须 ≥ 单个 proxy_buffer 大小,且 ≤ (数量 − 1) × 单个大小proxy_buffer_size 存 Header,再用 proxy_buffers 接 Body,proxy_busy_buffers_size 控制转发节奏如果你启用了 http2(如 listen 443 ssl http2),还有个隐藏关卡:
http2_max_field_size 16k:HPACK 解码后单个字段(比如一个超长 Authorization 值)的上限,默认仅 4khttp2_max_header_size 64k:所有 Header 总和上限(可选,但建议设)proxy_buffer_size 同量级,例如都设为 16k 或 32k
调大缓冲只是临时兜底,不是根本解法:
Set-Cookie、未清理的 X-Trace-ID、中间件注入的调试头