关于 Cannot assign requested address 错误

1 错误出现的原因

今天的生产环境上的应用出现了一个报错,应用连接不上kafka,经过排查发现,kafka服务端正常的,在客户端主机上telnet一下kafka的ip端口,发现出现Cannot assign requested address这个一个报错。
在网上找了一些资料,说这个错误的原因是由于linux分配的客户端连接端口用尽,无法建立socket连接所致,虽然socket正常关闭,但是端口不是立即释放,而是处于TIME_WAIT状态,默认等待60s后才释放。

2 解决方法

网上的教程上,有以下方法:
1)、调低time_wait状态端口等待时间
①. 调低端口释放后的等待时间,默认为60s,修改为15~30s
sysctl -w net.ipv4.tcp_fin_timeout=30
②. 修改tcp/ip协议配置, 通过配置/proc/sys/net/ipv4/tcp_tw_resue, 默认为0,修改为1,释放TIME_WAIT端口给新连接使用
sysctl -w net.ipv4.tcp_timestamps=1
③. 修改tcp/ip协议配置,快速回收socket资源,默认为0,修改为1
sysctl -w net.ipv4.tcp_tw_recycle=1
2)、增加可用端口:
①、 sysctl -a |grep port_range
net.ipv4.ip_local_port_range = 50000 65000 -----意味着50000~65000端口可用
②、vi /etc/sysctl.conf
net.ipv4.ip_local_port_range = 10000 65000 -----意味着10000~65000端口可用
注:改完后,执行命令“sysctl -p”使参数生效,不需要reboot。

注:这两个方法并没有去尝试,因为需要root权限。所以寻求其他方式解决

3 其他方式解决

1、既然服务端的kafka是没问题的,那么问题肯定是出现在客户端的主机上,所以尝试查询主机的用户连接数限制,以及当前用户连接数,使用了以下一些命令进行了查询。
netstat -na|wc -l //Linux连接数
ulimit -u //查看Linux文件打开数限制
lsof -p 进程号 | wc -l //查看进程文件打开数
ps aux | sort -k3nr |head -n 10 //查看进程CPU占用率前10名
2、发现主机上某个应用程序运行占用了大量的连接数,随后,将这个程序kill掉之后,发现kafka可以telnet的通了,应用也恢复了,最后将kill掉的程序重新启动起来,发现无异常,问题解决。

"cannot assign requested address"是一个错误信息,它通常出现在网络编程中。这个错误表示尝试将一个socket绑定到一个无效的地址上。引用和引用提到了在TCP服务和编程中可能出现该错误的情况。在这些场景中,当尝试将一个socket绑定到一个无效的地址时,操作系统会返回这个错误。这可能是由于地址无效、端口已被占用或者其他网络配置问题引起的。 在引用中提到了一个与Tomcat相关的错误信息,即"Cannot assign requested address: JVM_Bind"。这个错误通常发生在Tomcat服务器启动时,表示Tomcat无法将其服务绑定到请求的地址上。这可能是由于端口已被占用或者网络配置不正确引起的。 综上所述,"cannot assign requested address"是一个通用的错误信息,它可能出现在不同的网络编程场景中,表示尝试将socket绑定到无效的地址上。具体的原因可能是地址无效、端口已被占用或者其他网络配置问题。对于具体的错误,需要根据上下文和具体的场景进行排查和解决。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [cannot assign requested address错误解决](https://blog.youkuaiyun.com/skh2015java/article/details/104467217)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Cannot assign requested address错误解决](https://blog.youkuaiyun.com/m0_46392035/article/details/124767886)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [Tomcat Cannot assign requested address: JVM_Bind 非端口占用冲突](https://download.youkuaiyun.com/download/weixin_38691703/12787735)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值