码迷,mamicode.com
首页 > 其他好文 > 详细

Cannot assign requested address 问题

时间:2017-05-01 20:56:34      阅读:189      评论:0      收藏:0      [点我收藏+]

标签:报错   soc   回收   server   ann   cycle   线程   timestamp   问题分析   

測试一个简单的TCP套接字程序,clientserver请求建立连接然后释放。

在一台主机上同一时候执行两个client时。出现报错“Cannot assign requestedaddress”

server的请求处理改为3线程的线程池后问题解决。

但同一时候执行的client数量继续添加时,如15client同一时候执行,该问题再次出现。



在网上找到问题分析例如以下:

client频繁的连server,因为每次连接都在非常短的时间内结束,导致非常多的TIME_WAIT,以至于用光了可用的端口号。所以新的连接没办法绑定port,即“Cannot assign requested address”。是client的问题不是server端的问题。通过netstat,的确看到非常多TIME_WAIT状态的连接。

可见问题不在于server端,而是client端频繁建立连接,而port释放较慢。导致建立新连接时无可用port。

网上的解决方法:

运行命令改动例如以下2个内核參数(须要root权限) 
sysctl -w net.ipv4.tcp_timestamps=1  
开启对于TCP时间戳的支持,若该项设置为0。则以下一项设置不起作用

sysctl -w net.ipv4.tcp_tw_recycle=1  表示开启TCP连接中TIME-WAITsockets的高速回收。




Cannot assign requested address 问题

标签:报错   soc   回收   server   ann   cycle   线程   timestamp   问题分析   

原文地址:http://www.cnblogs.com/cynchanpin/p/6792565.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!