这个问题围绕本站有一段时间,因为程序运行良好,只有退出时出现这个问题,一直以来以为是discuz自身的问题。如:http://bbs.swdyz.com/member.php?mod=logging&action=logout&formhash=72dea2a2 要把后面&formhash=72dea2a2去掉才正常显示,但用户仍然不能退出!
]" a% i# ^$ J9 k4 `+ m0 F/ G! Z2 S8 B' e8 Y2 j
9 L8 p; \( v& s8 n: N今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:5 F. a2 G B7 A. f2 a6 t2 [$ [( ]
[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"
" f1 Y4 C/ N. Q: n6 x/ O- u
- d& e, S; H7 x+ d9 W, D) @
原因在这句:upstream sent too big header while reading response header from upstream" K3 ]0 M! P2 }+ }* @0 U
原来用户退出时发送的header过大,超出默认的1k。
3 h. k2 {1 K. `0 t4 l. M' a解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:& O- q. [# K b
fastcgi_buffers 8 16k; ( a$ F% E! P' k4 I( @
fastcgi_buffer_size 32k;
8 H9 C% g5 }4 g6 G0 \- P4 A2 ^% o# N" o8 D* Y: c+ G
3 C9 G: C, o7 u, E( e
如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:. h- Z L$ q V' n
在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入:/ j6 c& g" t" R% P# P2 j* T
proxy_buffer_size 128k;& V0 N1 g+ X+ n! _# o
proxy_buffers 32 32k;# \- x1 X6 [# K. k6 v
proxy_busy_buffers_size 128k;8 w8 p# c4 D& ~/ L
+ e& c! y3 ]& U1 Y& S9 \0 q/ _& L, t) n
! v/ J! n1 f7 b: \) C/ y! _
|