这个问题围绕本站有一段时间,因为程序运行良好,只有退出时出现这个问题,一直以来以为是discuz自身的问题。如:http://bbs.swdyz.com/member.php?mod=logging&action=logout&formhash=72dea2a2 要把后面&formhash=72dea2a2去掉才正常显示,但用户仍然不能退出!
6 D1 h) l1 b0 L0 J; C& ?7 Q! V6 ]" a8 J5 ]4 q6 [$ n3 }) P
8 a+ |6 o p5 ]1 B6 P
今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:: `% D: d6 W8 D7 S9 a# C
[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"
+ f# l6 U: J4 F* u+ k3 ?; X
: _- E4 D3 ? J+ Y3 D9 a0 K; q
原因在这句:upstream sent too big header while reading response header from upstream
- V' J' L$ f8 q: H8 G原来用户退出时发送的header过大,超出默认的1k。
$ r" h6 K0 ?- `解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:
4 q* L% ^. x2 j( \fastcgi_buffers 8 16k; , a* ]$ m. W; m, g S
fastcgi_buffer_size 32k;. N4 J% Y6 W2 X6 f5 X5 P" n
2 d5 a$ ~8 }3 m; b; L$ _# I7 R( D# e, q3 O+ r3 a
如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:
7 |6 N( r; l+ n+ u% E, n' x- m在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入:+ L- a9 h: y, }: Q9 i q# K7 W
proxy_buffer_size 128k;# l, v* C$ R5 `: z" f2 i& T1 }
proxy_buffers 32 32k;2 t1 ]( N S/ C i
proxy_busy_buffers_size 128k;
& l! u% @2 T. D0 O6 {) Y( X! _' j/ c5 _ x# D: r! h9 b* f
6 V+ Y; S6 C$ _; Q
( q6 |3 w- a' @9 C; S |