一问题描述
今天测试人员对我们使用beego开发的后端服务进行压力测试,每隔200ms Post一次数据,大概Post二百多次后,出现下面的Error:"Cannot assign requested address”,网上找了下原因,大致上是由于客户端频繁的连服务器,由于每次连接都在很短的时间内结束,导致很多的TIME_WAIT,导致建立新连接时无可用端口,新的连接没办法绑定端口,即“Cannot assign requested address”。是客户端的问题不是服务器端的问题。通过netstat,的确看到很多TIME_WAIT状态的连接。
二 解决方法
1.修改如下2个内核参数 (需要root权限)
sysctl -w net.ipv4.tcp_timestamps=1 开启对于TCP时间戳的支持,若该项设置为0,则下面一项设置不起作用
sysctl -w net.ipv4.tcp_tw_recycle=1 表示开启TCP连接中TIME_WAIT
sockets的快速回收
使配置生效: /sbin/sysctl
-p
2.创建连接回收池
可以考虑创建连接回收池,人为的控制管理连接数量。
三 原理分析