找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 25789|回复: 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去掉才正常显示,但用户仍然不能退出!
- u* b2 ~5 p8 Q6 ]* o5 q6 Z5 S/ c+ k
* A1 s' ?/ t8 z6 v
今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:
/ l( o) w( X/ E0 t5 N, K# w
[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"

+ ^# x; c" J0 C& r4 c! y+ z9 f8 G9 _" I3 U4 n/ V
原因在这句:upstream sent too big header while reading response header from upstream/ a' b: P8 t: C4 M4 B, N- m
原来用户退出时发送的header过大,超出默认的1k。
0 v5 R" y5 F% D$ z- @$ H8 }9 |+ M$ ~解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:
7 P& ]4 I9 \: \0 Y* n3 S0 Cfastcgi_buffers 8 16k;
4 E+ @; \* L3 G7 ~9 Y. D+ f% n4 r+ |* Ufastcgi_buffer_size 32k;5 c  a3 \3 t( t, A: k' q1 c# @

  _7 l; b1 i" t! ~) N
6 x# C, {, D/ X, F4 @  s5 k! T
如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:
3 E, E2 t- ^$ v& |2 v: d( i0 t在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入/ n0 @& J4 t. ^1 T1 [0 D6 h! j! Q8 U
    proxy_buffer_size 128k;
1 O; c/ b8 e8 s3 _( u/ y! K2 i    proxy_buffers 32 32k;: _5 o/ G7 h3 ]4 i0 s6 n. J2 G; Q
    proxy_busy_buffers_size 128k;: F: s. ]" e. V8 U

2 X3 w- L' ~4 Z  g. U+ F8 _4 H( @8 m
# s" v. q' `" N4 g& Z  L
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2026-5-16 21:58 , Processed in 0.102465 second(s), 25 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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