我们在redis服务器上有17k tcp连接处于关闭状态。我的理解是,只有客户端才会启动关闭连接,而不是从redis服务器。因此,我应该在redis服务器上看到0连接处于关闭状态。有没有人有一些经验,知道根本原因?
在'redis-cli信息‘中的实际connection#小于200,而且我们有足够的内存和cpu空闲时间超过90%。
我通过了http://redis.io/topics/clients上的redis文档。那里的任何东西都帮不了我找出根本原因。
redis version: 2.6.7
netstat -an|awk '/tcp/ {print $6}'|sort|uniq -c
1 CLOSE_WAIT
16980 CLOSING
128 ESTABLISHED
21 LAST_ACK
12 LISTEN
1 SYN_RECV发布于 2015-03-23 14:44:59
这是由我们用来连接到redis服务器的phpredis库造成的。
基本上,phpredis发送一个QUIT命令来请求redis服务器关闭连接。但是在这样做之后,phpredis就关闭了tcp套接字本身,导致双方都试图关闭连接。因此,服务器有那么多连接卡在CLOSING状态。
我为这个问题做了一个简单的修正。https://github.com/phpredis/phpredis/issues/562
https://serverfault.com/questions/675838
复制相似问题