这个问题围绕本站有一段时间,因为程序运行良好,只有退出时出现这个问题,一直以来以为是discuz自身的问题。如:https://bbs.swdyz.com/member.php?mod=logging&action=logout&formhash=72dea2a2 要把后面&formhash=72dea2a2去掉才正常显示,但用户仍然不能退出!& Q7 C+ R: s: _* U3 P
$ G9 b0 w4 c3 L. F7 n# m) U8 `. p
1 ~$ }6 n: |4 M/ I! p. a今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:
) K& b# r9 k% R9 H! T[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"
% e+ |. q6 n% w! I5 n: B/ D V7 h9 ~4 u; d
原因在这句:upstream sent too big header while reading response header from upstream& n$ c1 @$ m F" a+ t8 z
原来用户退出时发送的header过大,超出默认的1k。$ l3 j. o5 G/ x/ B
解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:( H& r; [6 \/ ^0 B4 {
fastcgi_buffers 8 16k; ) J7 n% c2 c0 r; k6 h: h. a
fastcgi_buffer_size 32k;6 B @: \. m ~* c$ O: G
. g: f$ Q$ i- E. T
S% L- ]# G. d; u& h$ y& Q如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:
( A6 h- b+ V8 A$ w0 Z在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入:
( N# v4 S1 c$ s0 }. R0 E- F proxy_buffer_size 128k;
4 j5 {2 V' I# M2 }/ u i. v' C' W; q proxy_buffers 32 32k;
' Q: r2 v M" x+ k5 d proxy_busy_buffers_size 128k;7 m4 R6 b% l- n" ~0 O4 Q
1 a% m- [: \2 k0 y L
8 C) w5 _2 T$ m# ]3 s$ i
2 `5 y$ ]- B3 n7 O2 a) }$ `/ Z
|