关于 Cannot assign requested address 异常问题的分析与处理

一、异常问题描述

当HTTP接口访问的并发量比较大时,操作数据库(例如MySQL)的接口会无法连接到数据库,并提示如下错误,可以使用jemter或wrk工具复现:

(1)PHP接口场景下:

Uncaught PDOException: SQLSTATE[HY000] [2002] Cannot assign requested address

(2)Java接口场景下:

java.net.NoRouteToHostException: Cannot assign requested address.

二、模拟高并发调用接口的测试工具

(1)jmeter工具:https://github.com/apache/jmeter

(2)wrk工具:https://github.com/wg/wrk

 

三、问题分析

       经网上查资料, 是由于linux分配的客户端连接端口用尽, 无法建立socket连接所致,虽然socket正常关闭,但是端口不是立即释放, 而是处于TIME_WAIT状态, 默认等待60s后才释放。
      查看linux支持的客户端连接端口范围, 也就是28232个端口:

cat /proc/sys/net/ipv4/ip_local_port_range
32768 - 61000

四、问题处理

1. 调低端口释放后的等待时间, 默认为60s, 修改为15~30s

echo 30 > /proc/sys/net/ipv4/tcp_fin_timeout

2. 修改tcp/ip协议配置, 通过配置/proc/sys/net/ipv4/tcp_tw_resue, 默认为0, 修改为1, 释放TIME_WAIT端口给新连接使用。

echo 1 > /proc/sys/net/ipv4/tcp_tw_reuse

3. 修改tcp/ip协议配置,快速回收socket资源, 默认为0, 修改为1.

echo 1 > /proc/sys/net/ipv4/tcp_tw_recycle

按照上述方法测试,问题得以解决!

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
"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.csdn.net/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.csdn.net/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.csdn.net/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、付费专栏及课程。

余额充值