性能测试发现“redis cannot assign requested address”问题

 

场景描述:test_client(jmeter) -> nginx -> redis

 

问题表现:nginx频繁报错redis cannot assign requested address,查看nginx网络连接情况,发现有大量TIME_WAIT的连接,并且test_client的tps上不去。大量的TIME_WAIT状态使得local port在TIME_WAIT持续期间不能被再次分配,即没有可用的local port,最终导致新建连接失败。

 

问题分析一:

大量TIME_WAIT出现的主要原因是nginx频繁与服务端建立tcp短连接后,又主动关闭tcp连接引起的。我们使用的openresty的redis库(resty.redis)已经有连接池的概念,且关闭tcp连接时使用set_keepalive方式,所以搞不清楚为什么nginx会频繁关闭tcp连接,导致出现大量TIME_WAIT的tcp连接。

 

问题分析二:

lua-resty-redis的set_keepalive函数最终调用的是lua-nginx-module的tcpsock:setkeepalive函数,此函数有两个参数(max_idle_timeout, pool_size),即最大空闲时间和最大连接池大小。使用set_keepalive把该连接放到连接池后,该连接到达最大空闲时间或者连接池到达连接池最大值时,会把连接池中最久未使用的连接关闭掉。原文如下:</

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
"Cannot assign requested address"是一个常见的错误信息,通常在连接Redis服务器时出现。这个错误提示表明客户端无法为新的连接分配一个可用的端口。有几种可能的原因导致这个错误出现。 一种可能的原因是并发访问量较大,处于TIME-WAIT状态下的TCP连接较多。在这种情况下,可以尝试使用pconnect替换connect来解决问题。pconnect是一个基于连接池的方法,可以重用已经建立的连接,而不需要频繁地创建和关闭连接。这将减少新连接的需求,从而避免了"Cannot assign requested address"错误的发生。 另一种可能的解决方案是调整操作系统的网络配置。通过增加系统的可用端口范围,可以提供更多的可用端口给新的连接。具体的配置方法取决于操作系统的类型和版本,可以参考相关的文档或者咨询系统管理员进行配置。 总结起来,解决"Cannot assign requested address"错误的方法有两种:一是使用pconnect来重用已经建立的连接,二是调整操作系统的网络配置以提供更多的可用端口。根据具体的情况选择合适的解决方案来解决该错误。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [TIME_WAIT引起Cannot assign requested address报错](https://blog.csdn.net/weixin_30266885/article/details/96400831)[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: 50%"] - *3* [Redis报错Cannot assign requested address解决方案](https://blog.csdn.net/SakuraLLj/article/details/131690549)[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: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值