这个问题围绕本站有一段时间,因为程序运行良好,只有退出时出现这个问题,一直以来以为是discuz自身的问题。如:http://bbs.swdyz.com/member.php?mod=logging&action=logout&formhash=72dea2a2 要把后面&formhash=72dea2a2去掉才正常显示,但用户仍然不能退出!* G5 Z; o1 `9 D
% x& ]& Z- F2 [0 O. ?# n
4 Q4 I" X! i+ [/ [$ o+ T4 L今天发誓解决的个问题,懒人终于查看了nginx的错误日志,里面显示:$ D0 i6 ?8 i* B7 d( Q1 u" n* {
[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"
- {3 s8 m) I. R! C
- a& ]; i: Q2 C1 f( P原因在这句:upstream sent too big header while reading response header from upstream/ O! U/ f4 e U9 T5 i$ L
原来用户退出时发送的header过大,超出默认的1k。! A+ ^% ~ Z9 V1 X% y
解决方法也就有了,在nginx网站php解析那部分加上以下代码问题解决:1 g9 T' Q" w) {+ }, _
fastcgi_buffers 8 16k; - B2 L+ E7 R# ]- ?
fastcgi_buffer_size 32k;
, @- y) R& Y: G& W5 b B3 @' q! j$ L. F+ T
5 s9 f6 e3 z8 C e4 p如果你已经设置但还是有问题估计用了反向代理的原因,同样反向代理nginx配置文件php部分加上:
( l1 g0 ^4 H4 }# C: z在http{}中加了如下代码,单个虚拟站点在location ~ \.php{}中加入:
; b8 K8 x8 P8 i* m' F& j. o proxy_buffer_size 128k;* ^2 q5 T4 j u! \$ S& h* {$ U1 H
proxy_buffers 32 32k;
) g; A/ U; A. f proxy_busy_buffers_size 128k;% @* x: _1 w$ E: _. i; m& o8 C5 c+ f
1 O4 \/ t: k& V, s' ]; ^% v+ s6 |$ o" f6 ~: C* [
% Q- l1 m. \* R$ g7 S- f
|