这个问题围绕本站有一段时间,因为程序运行良好,只有退出时出现这个问题,一直以来以为是discuz自身的问题。如:http://bbs.swdyz.com/member.php?mod=logging&action=logout&formhash=72dea2a2 要把后面&formhash=72dea2a2去掉才正常显示,但用户仍然不能退出!
( p9 V# ]) M% e$ I6 D( y+ W* g& |* G
$ X4 P& p/ M1 F' v) V
今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:
; X U/ ~2 @+ Z[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% v+ P) ^- v& n* e/ C
. K3 e' e- K6 d4 X- n原因在这句:upstream sent too big header while reading response header from upstream
* _: d# q( M+ b9 O$ `& H& T, Y原来用户退出时发送的header过大,超出默认的1k。
5 v3 f! D6 B# w7 n# H$ n解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:
% M4 r' A+ l0 k1 x4 y. L0 Z! kfastcgi_buffers 8 16k;
& V" w5 ~: f7 ^* {4 kfastcgi_buffer_size 32k;
0 o! |+ X, I. e3 E' {3 M5 n7 j. ]' ]
+ _3 ^6 L) J+ }* i
如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:
8 D, d7 q7 q K8 N% S在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入:- a F5 i: ? T* x* i
proxy_buffer_size 128k;
9 j$ ]% h& h2 O% h R: l; Z proxy_buffers 32 32k;# g% H" O7 B, j' w3 r8 f* n5 _
proxy_busy_buffers_size 128k;
8 z5 w: |* d% ?: o# X0 S- i6 v6 Y" h$ D C8 e- v" b( {
7 }& {) b# C8 s: ?6 l7 t
3 v& K! T. @$ S$ E8 }& u |