Cannot assign requested address 问题
2017-05-01 19:43
447 查看
測试一个简单的TCP套接字程序,client向server请求建立连接然后释放。
在一台主机上同一时候执行两个client时。出现报错“Cannot assign requestedaddress”
将server的请求处理改为3线程的线程池后问题解决。
但同一时候执行的client数量继续添加时,如15个client同一时候执行,该问题再次出现。
在网上找到问题分析例如以下:
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的高速回收。
在一台主机上同一时候执行两个client时。出现报错“Cannot assign requestedaddress”
将server的请求处理改为3线程的线程池后问题解决。
但同一时候执行的client数量继续添加时,如15个client同一时候执行,该问题再次出现。
在网上找到问题分析例如以下:
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 问题
- Cannot assign requested address问题
- linux--异常--NoRouteToHostException: Cannot assign requested address有关问题
- 新项目开发环境搭建遇到的问题排查(cannot assign requested address)
- BindException: Cannot assign requested address问题解决!!!
- java.net.BindException: Cannot assign requested address: Cannot bind问题解决
- Cannot assign requested address 问题
- 记问题解决:Cannot assign requested address:jvm_bind
- Caused by: java.net.BindException: Cannot assign requested address: JVM_Bind问题
- Cannot assign requested address 问题
- 记一次tomcat启动时的问题:Tomcat Cannot assign requested address: JVM_Bind 非端口占用冲突
- Cannot assign requested address出现的原因及解决方案
- redis提示Cannot assign requested address
- Linux 修改MAC地址提示:SIOCSIFHWADDR: Cannot assign requested address
- Cannot assign requested address
- Cannot assign requested address
- java.net.BindException: Cannot assign requested address
- tomcat java.net.BindException: Cannot assign requested address
- java.net.BindException: Cannot assign requested address: JVM_Bind
- 关于错误:java.net.BindException: Cannot assign requested address