Cannot assign requested address出现的原因及解决方案
今天使用python多线程请求服务时,出现Cannot assign requested address错误
网上找了下原因,大致上是由于客户端频繁的连服务器,由于每次连接都在很短的时间内结束,导致很多的TIME_WAIT,以至于用光了可用的端 口号,所以新的连接没办法绑定端口,即“Cannot assign requested address”。是客户端的问题不是服务器端的问题。通过netstat,的确看到很多TIME_WAIT状态的连接。
client端频繁建立连接,而端口释放较慢,导致建立新连接时无可用端口。
netstat -a|grep TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
tcp e100069210180.zmf: e100069202104.zmf.tbs:websm TIME_WAIT
解决办法
执行命令修改如下2个内核参数 (需要root权限)
sysctl -w net.ipv4.tcp_timestamps=1 开启对于TCP时间戳的支持,若该项设置为0,则下面一项设置不起作用
sysctl -w net.ipv4.tcp_tw_recycle=1 表示开启TCP连接中TIME-WAIT sockets的快速回收
Cannot assign requested address出现的原因及解决方案的更多相关文章
- 不能绑定到端口号:9194原因:Cannot assign requested address: JVM_Bind
晚上将老服务器程序从win2008部署在新的云服务器win2012上,其实就是复制过去改改配置,启动时突然报不能绑定到端口号:9194原因:Cannot assign requested addres ...
- com.sun.xml.internal.ws.server.ServerRtException: Server Runtime Error: java.net.BindException: Cannot assign requested address: bind
在发布 web service 时报错: Endpoint.publish(publishAddress, hl7MessageReveiver); com.sun.xml.internal.ws.s ...
- tomcat java.net.BindException: Cannot assign requested address 解决方法
今天线上TOMCAT启动时遇到了下比较麻烦的问题,错误如下: 21-Apr-2016 15:14:19.077 SEVERE [main] org.apache.catalina.core.Stand ...
- TIME_WAIT引起Cannot assign requested address报错
1. 问题描述 有时候用redis客户端(php或者java客户端)连接Redis服务器,报错:"Cannot assign requested address." 原因是客户端 ...
- Tomcat启动报错:严重: StandardServer.await: create[8005] java.net.BindException: Cannot assign requested address
org.apache.catalina.core.StandardServer await SEVERE: StandardServer.await: create[8005]: ...
- Dubbo广播模式下报错:Can't assign requested address解决办法
原因: 尝试使用Dubbo的multicast模式,发现一运行就报Can't assign requested address的错误,造成这种原因的主要是系统中开启了IPV6协议(比如window7) ...
- kafka.common.KafkaException: Socket server failed to bind to hdp1:9092: Cannot assign requested address.
ERROR [KafkaServer id=1] Fatal error during KafkaServer startup. Prepare to shutdown (kafka.server.K ...
- Tomcat启动异常 java.net.BindException: Cannot assign requested address: JVM_Bind
从Apache官网下载的tomcat7,在MyEclipse中启动时抛出如下异常: 严重: StandardServer.await: create[localhost:8005]: java.net ...
- DataNode启动不成功——java.net.BindException: Port in use: localhost:0 Caused by: java.net.BindException: Cannot assign requested address解决办法
爱折腾的人总是会出线各种奇怪的问题.记得之前听一位大师讲过,我们不能踩完前进路上的所有坑前进,而应该学会怎样避开前进路上的坑,踩得坑越多,可能你的经验越丰富,但是付出的时间代价可能不是经验能换来的.我 ...
随机推荐
- 调用约定__cdecl和__stdcall
首先,__cdecl,c declaration,C风格声明.或者 c default calling(笔者瞎编的).(那么问题来了,为什么PASCAL风格被称为std?) 调用约定的内容包括三点:参 ...
- DE2-115开发板学习(1_时钟信号引脚分配与复位信号的产生)
1.DE2-115开发板资源 Altera EPCS64 Configuration Device 64MB SDRAM (两片) 50MHz Oscillator EP4CE115F29C7(4PL ...
- 事件驱动之Twsited异步网络框架
在这之前先了解下什么是事件驱动编程 传统的编程是如下线性模式的: 开始--->代码块A--->代码块B--->代码块C--->代码块D--->......--->结 ...
- if、if elif判断
1.if.py #coding=utf-8 user = 'alex' passwd = 'alex3714' username = input('username:') password = inp ...
- Linux的一些常用快捷键和基本命令
*******1.在Linux中,只有/能够当盘符,/首先要分配给系统盘所在分区*******2.swap交换分区,相当于Windows下的虚拟内存,用来模拟内存,当内存不够用时,就会使用交换分区.其 ...
- ArcGIS Engine中的8种数据访问 (转)
数据是GIS的基础, 访问数据也是进行任何复杂的空间分析及空间可视化表达的前提.ArcGIS支持的数据格式比较丰富,对不同的数据格式支持的程度也有很大差异.本文主要介绍一下以下八种数据格式在ArcGI ...
- linux命令-dd {拷贝并替换}
一 命令解释: dd:用指定大小的块拷贝一个文件,并在拷贝的同时进行指定的转换. 注意:指定数字的地方若以下列字符结尾,则乘以相应的数字:b=512:c=1:k=1024:w=2 参数注释: if=文 ...
- R&S学习笔记(二)
1.OSPF:路由条目1万多条.收敛时间1s:ISIS:路由条目可以达2万多条,收敛时间50ms().ISIS在链路层上面,不依赖IP这层,这样给了它很多可能.比如IPv4, IPv6路由的混合承载, ...
- 集成IC刷卡器经验
因为一系列的原因,IC刷卡器要渐渐地取代磁条刷卡器.公司在这方面也是需要跟进的,在我负责集成IC刷卡器到应用程序的过程中,积累了些经验,现在分享下. 第一:无论是磁条还是IC刷卡器都是刷卡器的一种,所 ...
- LoadRunner测试结果分析03 转载至zhangzhe的新浪博客
LoadRunner测试结果分析之我见 前面分析的Web Resource(网络资源)的测试情况,其主要关注的是服务器性能,而系统本身和环境都有可能存在问题,页面诊断(Web Page Diagnos ...