这个问题围绕本站有一段时间,因为程序运行良好,只有退出时出现这个问题,一直以来以为是discuz自身的问题。如:http://bbs.swdyz.com/member.php?mod=logging&action=logout&formhash=72dea2a2 要把后面&formhash=72dea2a2去掉才正常显示,但用户仍然不能退出!. \/ E6 P$ U8 W
# d: f3 d9 K3 m8 l. g1 _# K5 X1 w ^
- c, k& i5 A) M, d' |
今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:
) ^ d7 B" Z7 W- ` 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: "http://bbs.swdyz.com/home.php?mod=space&uid=1&do=profile"
# d, O; w5 t) a' n+ S! N8 r
; f; h- [# H4 a9 ~/ T. ~原因在这句:upstream sent too big header while reading response header from upstream; D8 o# b, q; u7 M% i6 L0 o
原来用户退出时发送的header过大,超出默认的1k。
) Q. S* C0 T' R解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:9 s- ?, P$ w* k8 l
fastcgi_buffers 8 16k;
+ C8 j6 s) L0 U+ F& yfastcgi_buffer_size 32k;) I# Q/ f( z: }. \
d' m0 h2 U1 j& o! s a+ P! O0 i$ g" \+ @3 F ^
如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:, ^7 F# K* @# b, J6 Y: ]; ~
在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入:
H7 K7 y: w& k' L6 b+ @* V0 E proxy_buffer_size 128k;' K0 ?1 n2 C' G
proxy_buffers 32 32k;' x2 s, U: {" g* D
proxy_busy_buffers_size 128k;
& A( a5 V' Q4 M( I) I$ n
; f) V% B X! U. K
) c- [0 Y1 L- r/ v7 ]& ~& R- y6 u6 c, @; F
|