前情提要
在使用java web container的时候,我们都在前面挡一层nginx,方便使用各种nginx的功能,设置成代理。 访问特别多的时候发现,服务器上存在大量的TIME_WAIT状态的连接。 经分析,可能是nginx早期版本的upstream还是使用的1.0的短连接代理,java container老是以1.0的方式主动断开进入TIME_WAIT状态,浪费了大量的连接。
升级前
1 2 3 4 5 6 |
|
为了hold这些time_wait状态的连接,可以想象浪费了多少资源。
升级
下载最新稳定版本nginx-1.4.5,编译安装,按下不表。
修改配置添加keepalive字段到upstream。
1 2 3 4 5 |
|
同时修改配置添加http1.1声明和header中connection重写。
1 2 3 4 5 6 7 8 9 10 11 12 |
|
升级后
TIME_WAIT大量减少十倍以上! 内存占用降低有待考验。
原创文章如转载,请注明:转载自五四陈科学院[http://www.54chen.com]
捐赠说明