这个问题围绕本站有一段时间,因为程序运行良好,只有退出时出现这个问题,一直以来以为是discuz自身的问题。如:http://bbs.swdyz.com/member.php?mod=logging&action=logout&formhash=72dea2a2 要把后面&formhash=72dea2a2去掉才正常显示,但用户仍然不能退出!
0 S! d j( T/ f# b& x
7 x- C# @. v: E$ [% r: N- H' A0 i1 Z0 V+ F& i9 S" E
今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:
$ e8 {4 I) L% O3 q- O3 k t$ q[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"
" b# p9 x4 f- v, U
% _' B, h; A" h8 y( v
原因在这句:upstream sent too big header while reading response header from upstream
" g l5 f7 X0 D; V3 }. w原来用户退出时发送的header过大,超出默认的1k。3 M9 A. ]- J5 s
解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:
/ n- q T+ A: Xfastcgi_buffers 8 16k;
4 _% N- F) y% h" `- \( cfastcgi_buffer_size 32k;. |7 o, ~9 R/ e1 m
/ d& ?: c1 A& u) F S: e
" I; F, Q1 R0 S" J如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:
# s' Q5 I5 S* l ^+ [在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入:" b: T2 @0 i' Y& `
proxy_buffer_size 128k;1 e L6 d- J* r
proxy_buffers 32 32k;
$ u$ E3 b! ^6 e: b proxy_busy_buffers_size 128k;
+ q% g3 K+ G# `8 w
6 Z' @, y- T2 n+ m2 l( m6 o- W) n8 K
) |8 A& ^9 G6 I- x
|