Redis连接的客户端(connected_clients)数过高或者不减的问题解决方案

Posted 性能、可用性、伸缩性、扩展性、安全性、可监控是网站架构最核心

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Redis连接的客户端(connected_clients)数过高或者不减的问题解决方案相关的知识,希望对你有一定的参考价值。

最近的项目上使用ServiceStack.Redis上了redis缓存,其中遇到了很多问题。。 比如说 某一天发现redis做的缓存竟然失效了,然后查了下日志  报错max number of clients reached, sPort: 0, LastCommand:   。。首先考虑的是是不是项目中redis使用完后没有dispose..结果查了半天没发现有哪里忘记dispose。。 之后觉得是redis服务端可能出了问题 重启了下,过了段时间查看redis状态  info指令。。


可以看到connected_clients很高 。。多次监控后发现虽然有下降 但是还是在4000以上。

之后在用client list 指令 查看客户端连接情况


其中idle(以秒计算的空闲时长)竟然这么长时间。。很多空闲连接都没有被及时释放掉从而导致connected_clients非常高

查看redis的配置timeout (当客户端闲置多长时间后关闭连接,如果指定为0,表示关闭该功能)


然后设置timeout


再次查看connected_clients


瞬间就降下来了。。 至此问题解决!

 

 

 

以上是关于Redis连接的客户端(connected_clients)数过高或者不减的问题解决方案的主要内容,如果未能解决你的问题,请参考以下文章

Redis 客户端连接

阿里云-Redis-Help-连接实例-Redis客户端连接:Jedis客户端

redis客户端连接,最大连接数查询与设置

redis客户端连接,最大连接数查询与设置

redis客户端连接,最大连接数查询与设置

Redis 客户端连接