找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 25531|回复: 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去掉才正常显示,但用户仍然不能退出!$ J! o/ y0 J! z5 c8 l6 R5 t

. T0 t, u2 u* r- P: d. t. N5 d; `1 f) x, j# d3 N7 z4 a
今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:# ~3 Y6 L. R* M
[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"
6 w/ J0 _8 |. P; P9 r
8 h* B2 x1 c8 Q. E" u, s! O
原因在这句:upstream sent too big header while reading response header from upstream. J. z/ H+ j$ ?5 N( J; K) @5 b
原来用户退出时发送的header过大,超出默认的1k。
: b. v* X! t3 J" H" z+ p2 V* P' y: |解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:6 y( H" I0 w+ d3 v  Q
fastcgi_buffers 8 16k; ; N+ _3 W* _* Q" ^0 o/ p3 C" @
fastcgi_buffer_size 32k;
0 V$ a$ h' B& `  |& i3 r& H
3 k8 F3 v3 A/ n/ t6 `

' s0 r0 r; A, p9 h! S+ Y如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:
; Y- v% ]$ M) c- c9 c  Z在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入
# b; V* H- F1 }4 P    proxy_buffer_size 128k;
$ E! G( Q, i- g$ Y6 ?    proxy_buffers 32 32k;
- i! a* H  B! s4 {, V8 j    proxy_busy_buffers_size 128k;
" x5 _4 K5 l; R8 i4 ]- U7 A) ~( R9 L) O4 V3 B
/ ~5 Q, J1 b- l, ]' w6 x* \- N2 _5 F

' G/ v2 Z' k( P1 r. C
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2026-4-4 18:50 , Processed in 0.077629 second(s), 24 queries .

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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