这个问题围绕本站有一段时间,因为程序运行良好,只有退出时出现这个问题,一直以来以为是discuz自身的问题。如:http://bbs.swdyz.com/member.php?mod=logging&action=logout&formhash=72dea2a2 要把后面&formhash=72dea2a2去掉才正常显示,但用户仍然不能退出!! i( \3 o/ t( k. |( C) a
/ Y7 k2 J K2 R% K& d
) k2 @, Z$ N# l
今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:1 \3 b% z V) w6 S$ @! x
[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"
4 S1 o7 N5 f8 T' T2 |
8 a2 [& e% ]. ]+ l3 e' n, W; W6 t! F原因在这句:upstream sent too big header while reading response header from upstream
1 H6 z- X- S3 t' L4 s4 R4 D原来用户退出时发送的header过大,超出默认的1k。
! ?+ @4 b( L# ]2 u1 D解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:$ N) @. \7 H% M: j" }1 O: }5 _
fastcgi_buffers 8 16k;
; W) S. a8 F3 P# |fastcgi_buffer_size 32k;7 d S4 q# F6 K8 Z
0 {5 N4 R; d( p3 P j; g+ N; y
& x" U L7 d" Z7 P
如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:
1 z* q$ ]7 d& m5 T, C在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入:7 K/ U' H3 \" w1 V
proxy_buffer_size 128k;- W, ]3 H) ]/ D9 t/ h" i1 q, g
proxy_buffers 32 32k;
2 C3 z, ?. ?! Z: y proxy_busy_buffers_size 128k;
* ]* {" ^- m/ U) n( ]* f9 `3 q& i' e; _) h# R
( Y8 k+ d" D9 U! U0 H7 m4 S2 C
|