这个问题围绕本站有一段时间,因为程序运行良好,只有退出时出现这个问题,一直以来以为是discuz自身的问题。如:http://bbs.swdyz.com/member.php?mod=logging&action=logout&formhash=72dea2a2 要把后面&formhash=72dea2a2去掉才正常显示,但用户仍然不能退出!
5 _: U9 _) Y9 M9 t/ A/ K8 P
- w, [' y! H ?7 D, ~$ W$ f2 r1 O* Y& W% o- x3 b4 \
今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:1 c4 u& X- {; U. 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"
5 R2 ]. A2 f% M( ]2 w) j. i6 B: i5 F
! J. C( R0 S# p2 Z
原因在这句:upstream sent too big header while reading response header from upstream; L, K2 W, z# ^# I3 a& j8 j7 h) x8 X
原来用户退出时发送的header过大,超出默认的1k。' h3 k6 N) p, f
解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:
3 i( p/ U1 E2 n* [7 F* O. Ifastcgi_buffers 8 16k; . Q$ L* u$ x7 E! @! M1 ]
fastcgi_buffer_size 32k;
: @* q( p% L1 J) D6 |, d9 b- G `( @/ X! }7 X0 S) C: F1 R i% p) `
/ ]# D. h# A" L. N, f6 ]0 Z5 ^
如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:
6 x# r# m, G7 J# e' t( t$ D在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入:
3 M2 V2 E& l% a5 H2 f proxy_buffer_size 128k;% B6 H/ i' L7 K H% H% a" z
proxy_buffers 32 32k;
' @9 E' S4 F" p" U! `' G proxy_busy_buffers_size 128k;
# A0 o# C, \; |, d
{' Z" |9 R8 o) J# |# H' k+ J B- o9 [
( |) H9 M7 B, ?9 \ c3 Y7 z2 y
|