这个问题围绕本站有一段时间,因为程序运行良好,只有退出时出现这个问题,一直以来以为是discuz自身的问题。如:http://bbs.swdyz.com/member.php?mod=logging&action=logout&formhash=72dea2a2 要把后面&formhash=72dea2a2去掉才正常显示,但用户仍然不能退出!
* ~0 \) H2 p/ A' y: M9 H. V/ B$ \, B( N5 K
+ \, W- d, `, v+ S/ l2 V
今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:
' A( I% F5 S6 N3 g; 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"
! G. |+ ^; t1 R8 A
/ ]! E4 b4 Q0 B. n( f
原因在这句:upstream sent too big header while reading response header from upstream/ [- f& | x" P4 Z# |
原来用户退出时发送的header过大,超出默认的1k。; r- G( W9 V7 u2 B6 y
解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:
* O$ K D. Z( u3 b& kfastcgi_buffers 8 16k;
* z4 m/ {) l2 e6 Tfastcgi_buffer_size 32k;& T) n: J8 e7 ?( h5 }) M6 Z1 V. ^
7 m* w1 D/ J/ l8 R
# |+ X: z- W3 k0 N+ s) [
如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:
5 z$ P$ R% w* b- |' w- \' k7 M8 {在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入:
5 k; Y. i8 j% s A proxy_buffer_size 128k;
3 J7 n" o3 f+ @7 T9 e+ w: N) c proxy_buffers 32 32k;' x6 ~5 \9 h$ d6 M. W
proxy_busy_buffers_size 128k;
5 F- ^! V* e/ G; c$ |! T; Z/ q7 q2 }
" ]4 Y; A: d( E- V8 {; ?6 V
3 u# G. j9 A7 }2 X# E
|