这个问题围绕本站有一段时间,因为程序运行良好,只有退出时出现这个问题,一直以来以为是discuz自身的问题。如:http://bbs.swdyz.com/member.php?mod=logging&action=logout&formhash=72dea2a2 要把后面&formhash=72dea2a2去掉才正常显示,但用户仍然不能退出!
: @! h% q7 w6 W$ `# y4 l# c, M
: C* Q' ]" n( a+ ~4 h. x9 `
7 _0 l' |" u, A5 j$ g+ ^今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:
6 g, M$ |* A* k: X7 a. d. k[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"
! e2 `$ N, N$ x& L- E0 p
8 A, x& L5 g. G, p, f原因在这句:upstream sent too big header while reading response header from upstream
! a6 ^" ?3 ~& b+ V* d: E原来用户退出时发送的header过大,超出默认的1k。
$ F0 c% C6 D C" x4 R. j" ~解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:( Y7 t; F( J3 ^3 L7 X
fastcgi_buffers 8 16k; ( W' y" W0 L4 r& G) N
fastcgi_buffer_size 32k;; p4 o e9 B4 D) q9 `
7 I: T6 g5 l: z. e# B$ ?
7 y1 j' r8 O2 G; K% ?: f+ L; T3 A
如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:. f: o" @' _ s7 z- V" ^) m% M
在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入:; ]4 S2 ?, X9 s( q: |7 c
proxy_buffer_size 128k;
# z. W, \$ G6 Y- E proxy_buffers 32 32k;3 I$ w# `/ P4 b+ M- s7 K. U1 G* t
proxy_busy_buffers_size 128k;
l3 u" f* R. e
0 o* t) G$ e4 M) ^2 E m$ r
! L! ^( \ v/ F! S( G# v' {" M/ ^) B! y, y: |+ |
|