这个问题围绕本站有一段时间,因为程序运行良好,只有退出时出现这个问题,一直以来以为是discuz自身的问题。如:http://bbs.swdyz.com/member.php?mod=logging&action=logout&formhash=72dea2a2 要把后面&formhash=72dea2a2去掉才正常显示,但用户仍然不能退出! N* F# Q% M% O& W3 u- x
K' V/ N1 ?8 m/ L2 A- E
; ^+ C2 g/ h; _2 u3 s. M; g
今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:
; _& l# `- o0 K[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"
' |$ j+ r7 k) z; I% ^( X6 s, P; a: \
原因在这句:upstream sent too big header while reading response header from upstream( M) Y' Y( ] a' `* z& \
原来用户退出时发送的header过大,超出默认的1k。
, X/ V4 v+ V0 w' u2 ~$ e* s. Q解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:
$ Y1 h% G2 }" F+ U7 mfastcgi_buffers 8 16k;
3 I6 g* s. F1 O' I9 l& L- Hfastcgi_buffer_size 32k;
* [0 q: b/ }( L9 G7 C) r5 g
6 @0 y$ P. U& a: X% R* f3 v! D8 E. T
如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:0 b* D! N3 O& ^, g3 o p
在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入:
6 O2 e2 g2 N( T4 w proxy_buffer_size 128k;
O% K7 S) _6 n$ |7 b: m% ? proxy_buffers 32 32k;
( u: Q# S( D, w1 x) p/ B proxy_busy_buffers_size 128k;( d: X2 Y' u4 P3 T
$ ~% l6 H- i: T( h0 |4 [3 w( t. _) x
9 {5 e7 d5 _6 G$ l i |