这个问题围绕本站有一段时间,因为程序运行良好,只有退出时出现这个问题,一直以来以为是discuz自身的问题。如:https://bbs.swdyz.com/member.php?mod=logging&action=logout&formhash=72dea2a2 要把后面&formhash=72dea2a2去掉才正常显示,但用户仍然不能退出!2 u" t$ C8 t3 r- L. ~
" [- j6 R# W$ z4 U( D2 o8 X0 y! [& Q9 O
今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示: x F8 P2 l+ B3 ?1 R
[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: "https://bbs.swdyz.com/home.php?mod=space&uid=1&do=profile"
* A$ Y3 `# e; M! \
. y+ i! q. b1 k$ x
原因在这句:upstream sent too big header while reading response header from upstream+ n7 b* `/ _, h, H9 @
原来用户退出时发送的header过大,超出默认的1k。
5 {% v/ |0 k0 a7 @& T. D# M( t" z解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:- E/ ]" Y" y0 N% O4 Z
fastcgi_buffers 8 16k;
8 v8 W: y Q% R) V S1 {fastcgi_buffer_size 32k;
, @1 n$ B, X, _* R ?' f1 _
$ I0 t- f# c; h9 Q1 D/ i! c. @6 J0 x5 Q u) _
如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:
2 r* \! ]8 L' M/ }7 r4 {在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入:
, @, Y5 O2 [: v' P. O proxy_buffer_size 128k;9 m' y& h9 u! w' W
proxy_buffers 32 32k;7 h7 g! ]5 z4 m( }0 A/ V) O
proxy_busy_buffers_size 128k;. r$ P( B5 E" [% g+ p
; z% D* y3 c' `" H7 b) L3 Y4 ~& _
4 N& l3 W6 J/ X% h2 G1 M+ C |