这个问题围绕本站有一段时间,因为程序运行良好,只有退出时出现这个问题,一直以来以为是discuz自身的问题。如:https://bbs.swdyz.com/member.php?mod=logging&action=logout&formhash=72dea2a2 要把后面&formhash=72dea2a2去掉才正常显示,但用户仍然不能退出!, f4 d8 c' `" G5 g7 R" i
+ g2 z& T/ ]7 w- l2 d, r2 Y/ s- u j) q' i; N& V5 {' G0 Q
今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:
' d5 I0 [2 ]- o" g[C#] 纯文本查看 复制代码 2014/08/07 08:44:17 [error] 1681#0: *49837 upstream sent too big header while reading response header from upstream, client: 218.65.212.158, server: bbs.swdyz.com, request: "GET /member.php?mod=logging&action=logout&formhash=72dea2a2 HTTP/1.1", upstream: "fastcgi://127.0.0.1:9009", host: "bbs.swdyz.com", referrer: "https://bbs.swdyz.com/home.php?mod=space&uid=1&do=profile"
{0 p, ~( m# D$ I0 R8 X! ~: ~# T# d$ r3 b* @! Y+ ]
原因在这句:upstream sent too big header while reading response header from upstream
0 z6 r8 a N+ E原来用户退出时发送的header过大,超出默认的1k。; W, F/ b9 ~" F+ j# j: Y
解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:
) ^$ o5 {9 h' W& u6 S' B0 Mfastcgi_buffers 8 16k; + H9 ?, q0 D, Q3 Y
fastcgi_buffer_size 32k;
7 ?% A! B) r. n/ @8 V
) H; K( c' p+ i7 D+ y" e; ~( E$ t4 p+ D6 }
如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:! Y7 N! j' J% z/ n
在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入:! b2 Q( [( n6 ~. A3 F1 \& f
proxy_buffer_size 128k;& ?% p" L0 x, Q5 C5 T" B3 I
proxy_buffers 32 32k;
* A* Y3 S2 C- y/ |! u4 ] proxy_busy_buffers_size 128k;3 n3 r- P4 t! R4 }; N! P" ?4 C
4 ]: ^6 S0 ]* b; u& C3 f
/ i# }$ m9 k4 z& k+ W2 E( a) B& z& b: `
|