Redis Cannot assign request address一案例标题文章
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Redis Cannot assign request address一案例标题文章相关的知识,希望对你有一定的参考价值。
参考技术A 1.背景:短链接,系统频繁连接、断开,导致系统大量的TIME_WAIT,导致系统很快用光了端口,新的连接没法绑定端口,redis 报如下错误:
登陆系统发现了大量处于TIME_WAIT 状态的连接:
2.解决方法:
[root@kk-redis-device01 ~]# sysctl -w net.ipv4.tcp_tw_recycle=1
error: permission denied on key 'net.ipv4.tcp_tw_recycle'
mv /sbin/modprobe /sbin/modprobe.old
rm -f /sbin/modprobe
ln -s /bin/true /sbin/modprobe
mv /sbin/sysctl /sbin/sysctl.old
rm -f /sbin/sysctl
ln -s /bin/true /sbin/sysctl
系统存在大量TIME_WAIT状态的连接,通过调整内核参数解决:
vi /etc/sysctl.conf 编辑文件,加入以下内容:
net.ipv4.tcp_syncookies = 1
net.ipv4.tcp_tw_reuse = 1
net.ipv4.tcp_tw_recycle = 1
net.ipv4.tcp_fin_timeout = 30 然后执行
/sbin/sysctl -p让参数生效。
参数解释:
net.ipv4.tcp_syncookies = 1 表示开启SYN Cookies。当出现SYN等待队列溢出时,启用cookies来处理,可防范少量SYN攻击,默认为0,表示关闭;
net.ipv4.tcp_tw_reuse = 1 表示开启重用。允许将TIME-WAIT sockets重新用于新的TCP连接,默认为0,表示关闭;
net.ipv4.tcp_tw_recycle = 1 表示开启TCP连接中TIME-WAIT sockets的快速回收,默认为0,表示关闭。
net.ipv4.tcp_fin_timeout 修改系统默认的 TIMEOUT 时间。
3.引出问题:TIME_WAIT存在的意义?
从网上找到TCP 四次挥手图解:
4.结论:
内核参数的优化是细节,尤其关注一些比较重要的、需要根据情况来优化自己的参数。
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 Cannot assign request address一案例标题文章的主要内容,如果未能解决你的问题,请参考以下文章
解决Creating Server TCP listening socket 54.179.160.162:7001: bind: Cannot assign requested address(示例
[译]Python - socket.error: Cannot assign requested address
FlinkFlink SQL Cannot instantiate user function cannot assign instance LinkedMap FlinkKafkaConsum