找回密码
 立即注册
查看: 21656|回复: 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去掉才正常显示,但用户仍然不能退出!4 V  h$ U% T- H$ |4 @
, Z' S: V( Z1 D0 j, e5 j, q
: @; N% I9 s$ [& O2 V' r9 B3 L
今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:- O0 |3 t8 L5 w$ o% F
[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"& L, U1 D1 q& E6 \  W: _  k
[/mw_shl_code]
) Q* r4 k9 @9 c  K3 Q
2 U7 \3 z; O3 F; g& l! r原因在这句:upstream sent too big header while reading response header from upstream( f4 |. o7 j- q
原来用户退出时发送的header过大,超出默认的1k。
; @0 R3 E: b" l' h* k) }* i解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:
  c$ y' i. v3 D/ s7 ~. Ffastcgi_buffers 8 16k;
  ]* j2 @; u/ J+ Bfastcgi_buffer_size 32k;3 K; Y  \" Z: ^, d# p" ]

* t! L( h& u2 Y- [2 i' u

5 p/ e' t) |0 m2 c- _如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:8 {1 A- `" \) S2 S* Q* _0 @
在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入# @- x. O+ o6 I, W7 K3 _+ Q. Y8 D
    proxy_buffer_size 128k;
, V) ]9 ^5 x; V+ T; {+ }% Y    proxy_buffers 32 32k;
  C. D; ]! c' M: {' p& x  L    proxy_busy_buffers_size 128k;: h0 x8 ?. {. @$ I$ D1 z
5 h' h" }4 t( L+ z/ D/ k8 k6 [

; k) @5 g1 y+ D7 \( `! {$ p4 f3 B% C/ \1 f2 k
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2024-4-19 19:41 , Processed in 0.067654 second(s), 22 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

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