redis数据导出,报错Could not connect to Redis at ip:port: Cannot assign requested address解决方法

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了redis数据导出,报错Could not connect to Redis at ip:port: Cannot assign requested address解决方法相关的知识,希望对你有一定的参考价值。

因为需啊把redis的数据导出和数据库数据作对比,用管道符连接的方式导出数据:


/opt/$company_name/redis-3.0.5/bin/redis-cli -h $IP -p $PORT  -a  $PASSWORD  keys  \* |xargs -n 1 /opt/$company_name/redis-3.0.5/bin/redis-cli -h   $IP -p $PORT -a  $PASSWORD  get > key.txt 


导出过程中,报错 :

Could not connect to Redis at IP:PORT,Cannot assign requested address.


这是因为客户端频繁的连服务器,数据量较大的时候,由于每次连接都在很短的时间内结束,导致很多的TIME_WAIT,以至于用光了可用的端口号,所以新的连接没办法绑定端口,即“Cannot assign requestedaddress”。


是客户端的问题不是服务器端的问题。通过netstat,的确看到很多TIME_WAIT状态的连接。

执行命令修改如下2个内核参数  

sysctl -w net.ipv4.tcp_timestamps=1     #开启对于TCP时间戳的支持,若该项设置为0,则下面一项设置不起作用

sysctl -w net.ipv4.tcp_tw_recycle=1      #表示开启TCP连接中TIME-WAIT sockets的快速回收

执行后,再执行开头的导出命令,不再报错了。


本文出自 “linux与网络那些事” 博客,请务必保留此出处http://khaozi.blog.51cto.com/952782/1750786

以上是关于redis数据导出,报错Could not connect to Redis at ip:port: Cannot assign requested address解决方法的主要内容,如果未能解决你的问题,请参考以下文章

redis报错Could not get a resource from the pool 仅登录用户可见

R语言连接MySQL报错:could not run statement: The used command is not allowed with this MySQL version

weblogic 12c下jxls导出excel报错Could not initialize class org.apache.poi.xssf.usermodel.XSSFVMLDrawing

关于ruby安装在windows gem install redis-dump 报错:MSYS2 could not be found

Redis链接中JedisPool报错Could not get a resource from the pool(无法从连接池中获取资源)

Redis链接中JedisPool报错Could not get a resource from the pool(无法从连接池中获取资源)