这个问题围绕本站有一段时间,因为程序运行良好,只有退出时出现这个问题,一直以来以为是discuz自身的问题。如:http://bbs.swdyz.com/member.php?mod=logging&action=logout&formhash=72dea2a2 要把后面&formhash=72dea2a2去掉才正常显示,但用户仍然不能退出!; u/ e; x9 D) ]1 J& A C' @9 b
6 H2 l& ~, C; @, d: A
6 e5 t' I& {4 \) a" T q. p! Z6 X
今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:" m2 D7 p. X: H
[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"
1 u" R! O5 T# t( N# Q S. L
( N7 Q6 q {5 j& ]4 V原因在这句:upstream sent too big header while reading response header from upstream, L; o% ~1 e8 o0 r& U" ]
原来用户退出时发送的header过大,超出默认的1k。% i" ?3 M0 m- n( Q0 `( [' | W
解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:
0 q1 ]$ E1 w6 W( f6 ofastcgi_buffers 8 16k;
; Q3 C6 t* L" a9 pfastcgi_buffer_size 32k;+ C- K7 U9 I* }! |4 y- ?
. l+ `" k8 e! q5 N
9 P- c) J4 k1 K* Q
如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:
9 X3 l% B ]# C' L4 d2 T在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入:
; Z4 b5 X, ]. A5 ^9 u5 Y proxy_buffer_size 128k;
5 N3 V2 o2 M7 X) F6 }* r7 o proxy_buffers 32 32k;, E2 \9 c# U+ u* [, }& W! d
proxy_busy_buffers_size 128k;
/ N. U' h- [9 G9 }: i3 ]* V9 K, k- Z/ y- y
) K! r) |0 Q; b# p7 s
0 U& J+ o# Z; f2 v4 l |