找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 25172|回复: 0

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

[复制链接]
发表于 2014-8-7 09:33:51 | 显示全部楼层 |阅读模式
这个问题围绕本站有一段时间,因为程序运行良好,只有退出时出现这个问题,一直以来以为是discuz自身的问题。如:https://bbs.swdyz.com/member.php?mod=logging&action=logout&formhash=72dea2a2 要把后面&formhash=72dea2a2去掉才正常显示,但用户仍然不能退出!
! X7 `5 c  R5 P4 i5 m
9 v3 w' Y2 [, p1 @. z" G  I; P$ E* ^* k3 i, o0 j4 R+ U. T- Q
今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:
$ P$ g7 o, Z4 p1 Q) d; Z
[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: "https://bbs.swdyz.com/home.php?mod=space&uid=1&do=profile"

) N! s) F; _: `8 g1 p# ^
( G5 e) t3 t0 E+ B' W原因在这句:upstream sent too big header while reading response header from upstream* K% n5 u. l) b5 p. d& E, T
原来用户退出时发送的header过大,超出默认的1k。- ~3 r- F+ q. I/ N9 |: ?
解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:7 q. @5 U* i* ]- J
fastcgi_buffers 8 16k; ( j" y. n% H+ g$ J5 f) S1 q
fastcgi_buffer_size 32k;1 W, ?; ~. ^" j/ O- O! ~
! ?3 H2 p8 I% U4 g1 K7 B
. ^9 o( u: Y" ^' f
如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:
& r: ~* B- q' |& N' E在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入3 a, y/ Z2 c0 f7 F' U' B% g* b: J
    proxy_buffer_size 128k;
0 @3 s: o4 D& q' o    proxy_buffers 32 32k;
) x$ ?# x  K% y$ O+ F/ L1 U+ O8 z    proxy_busy_buffers_size 128k;
7 k! a& ~3 c1 E% h* y% U3 x  ~7 }; n  [3 P. q" {, v4 x

+ D6 y' e4 o. v9 g# ]" g! b1 A3 e1 Z, t' y' m4 T: w" ^3 Y, p' ~
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2026-1-11 07:45 , Processed in 0.086119 second(s), 24 queries .

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

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