这个问题围绕本站有一段时间,因为程序运行良好,只有退出时出现这个问题,一直以来以为是discuz自身的问题。如:https://bbs.swdyz.com/member.php?mod=logging&action=logout&formhash=72dea2a2 要把后面&formhash=72dea2a2去掉才正常显示,但用户仍然不能退出!; r9 A _1 X' @$ E$ Q
* F0 }# _ r3 b# T" j. h- e' b. B& a
今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:
" `/ `) j D+ `/ |- B[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"
- P) d' d; |% m+ ?9 E M
7 q$ S2 q& s' A8 ^' A原因在这句:upstream sent too big header while reading response header from upstream1 e+ @# E! ~; J. @) E' I. H6 S
原来用户退出时发送的header过大,超出默认的1k。
% ]1 k& Q& o- U* W; z: D f5 S解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:
2 M& q1 H3 @7 a, S* _fastcgi_buffers 8 16k; ; T$ X' t: m! h) `/ @( V
fastcgi_buffer_size 32k;
7 J# ?; g: y; ?/ `
+ R6 y: E: n) F7 U* `( Q& W- A/ |
- j' ^: m6 k# X4 w7 E如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:0 D- h" z) O6 s, M+ L2 ?
在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入:/ a p. r6 O) }2 l. s1 Q
proxy_buffer_size 128k;
3 W: P# _9 Q+ k9 i2 J) V proxy_buffers 32 32k;5 l y" W/ M% i2 a: [' P3 w
proxy_busy_buffers_size 128k;
5 x+ u+ A( ^* m& `1 s0 n1 g
0 L' S0 e) l M( D) J# c2 j4 G$ V% Y
% F' Z: E) }6 u! j |