redis 获取不到资源和超时问题解决方案和步骤

1. 网络问题排查
   客户端 (多操作几次)
   telnet host 6379 
   redis-cli --latency-history -h host -p port 看看监控延迟性能
   ping 

2. JedisPool连接数设置检查
客户端 netstat -an | grep 6379 | grep EST | wc -l 
如果没有明显超过或者接近就可以排除JedisPool连接池配置的影响

3. 代码查看,看看每次执行之后是否释放或者关闭连接,注意异常代码捕获

4. 检查是否发生nf_conntrack丢包(/var/log/messages)
   具体参考连接 https://blog.csdn.net/weixin_34262482/article/details/91993791

5. 检查是否TIME_WAIT问题
   通过ss -s 查下
   过多: 
   sysctl -w net.ipv4.tcp_max_tw_buckets=180000
   sysctl -w net.ipv4.tcp_tw_recycle=1

6. DNS 问题
   可以绑定hosts地址,还存在,则不是DNS问题

7. 抓包分析
   ip a 查下网卡地址
   tcpdump -i 网卡地址 tcp and port 6379 -n -nn -s 74 -w xx.cap

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值