找回密码
 立即注册
查看: 21519|回复: 0

discuzx3.x用户退出显示502或503错误的解决方法

[复制链接]
发表于 2014-8-7 09:33:51 | 显示全部楼层 |阅读模式
这个问题围绕本站有一段时间,因为程序运行良好,只有退出时出现这个问题,一直以来以为是discuz自身的问题。如:http://bbs.swdyz.com/member.php?mod=logging&action=logout&formhash=72dea2a2 要把后面&formhash=72dea2a2去掉才正常显示,但用户仍然不能退出!
( v& o9 w. I: }  {& _8 U; N! _. m4 H) w4 |! S. n$ V

9 U8 ~0 a" b9 K7 ~今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:. i" D/ ]. c5 o3 f& S6 ^
[mw_shl_code=csharp,true]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 Z$ ^/ b. t! q5 Z7 @1 h
[/mw_shl_code]
4 Z7 F  W$ W3 x
+ L% J0 _* A: t6 i; V原因在这句:upstream sent too big header while reading response header from upstream
' y: |3 ~4 p7 W4 N) y5 r原来用户退出时发送的header过大,超出默认的1k。- l- {: V/ R/ W! L' O
解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:3 x4 x9 r: y" i" Q
fastcgi_buffers 8 16k;   a: W/ B  Z; D3 F. \6 ~: d3 F
fastcgi_buffer_size 32k;# I+ [, V6 Y( L& m+ P- j) H8 ]

$ y6 q3 T  E6 r" i

7 s% c+ z7 r6 t+ j, E如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:$ D* Q% W- X* e, [- S
在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入+ `0 l/ [& O+ a. ~, S0 P% R: Z
    proxy_buffer_size 128k;
3 N0 y  m' `2 N! r. Q8 D6 A    proxy_buffers 32 32k;1 L4 E5 p. c* z& m) o2 d
    proxy_busy_buffers_size 128k;
1 _- o' ]) q* L# y$ I% u4 v. E: w7 g

1 n  w# a4 P+ e6 M+ k0 C1 z/ M
2 S& b0 L- }+ p; f) R4 [5 L
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|第一站论坛 ( 蜀ICP备06004864号-6 )

GMT+8, 2024-3-19 16:44 , Processed in 0.070664 second(s), 20 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表