找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 25760|回复: 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去掉才正常显示,但用户仍然不能退出!( G% N* j& ]4 Y/ F+ x8 @* V# @+ B
# F) `9 V4 o0 N+ O
/ |/ ~4 F5 ?5 R7 K
今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:
4 X, E$ V# M. k; ?7 Y( I
[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"

9 d4 z) O) t- q0 ]3 @) X' H7 f6 O. K; d2 z( s3 f! l
原因在这句:upstream sent too big header while reading response header from upstream3 s+ `) ^/ W3 u9 y$ f7 Q$ v
原来用户退出时发送的header过大,超出默认的1k。% e8 j! R+ w& Z  ]# F6 X) K- [2 d
解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:
6 X2 h7 E$ b& H. Gfastcgi_buffers 8 16k;
- |7 @! Z6 J. _  ^, e  P" C- i8 Kfastcgi_buffer_size 32k;
; ~$ x, }6 c" `. l/ R$ E8 k( }$ @" E1 y# u( t
5 a) i/ G% F' |# f8 \$ V# y
如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:
- K0 u4 U5 Y4 m* l7 w& H在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入
1 Y1 s6 v" t& a    proxy_buffer_size 128k;. ~* O# o# X6 h/ f1 U
    proxy_buffers 32 32k;
6 `8 @. m) b# J! a3 \5 D/ g9 n    proxy_busy_buffers_size 128k;
- N: H# L: E! S; l, j
7 }0 q4 e4 `. I) g: _% Y' o& ~, Y6 E

, v3 Y6 K: v, q" ]( ~( W& x! s3 O. d
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2026-5-12 07:40 , Processed in 0.066602 second(s), 22 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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