杰克工作室 发表于 2023-2-23 15:51

处理redis连接数过多[综合处理]?

<h2><strong>故障描述:</strong></h2>

<p>redis服务器连不上,应用程序报错获取不到连接,内存勾兑和状态报告程序都会出问题<br />
&nbsp;</p>

<h2><strong>故障分析:</strong></h2>

<p>redis服务器默认设置的最大连接数maxclients是10000,但是受服务器最大文件数影响,服务器默认最大文件数是1024,所以redis最大连接也为1024-32=992,由于网络原因或连接未正常关闭导致redis服务器连接数接近990左右,应用程序连不上redis。<br />
&nbsp;</p>

<h2><strong>故障处理:</strong></h2>

<p>修改服务器最大文件数</p>

<h5>vi&nbsp;/etc/&nbsp;scurity/&nbsp;limits.conf</h5>

<p>添加</p>

<h5>*&nbsp;soft&nbsp;&nbsp;&nbsp;&nbsp;nofile&nbsp;&nbsp;65536&nbsp;&nbsp;<br />
*&nbsp;hard&nbsp;&nbsp;&nbsp;&nbsp;nofile&nbsp;&nbsp;65536</h5>

<p><br />
设置最大文件数65536,内核参数对文件描述符也有限制,如果设置的值大于内核的限制,也是不行的,需设置</p>

<h5>vi&nbsp;/etc/sysctl.conf</h5>

<h5>&nbsp;fs.file-max=65535</h5>

<p>sysctl&nbsp;-p生效,设置好用ulimit&nbsp;-a&nbsp;可以看到open&nbsp;files为65535,但是用cat&nbsp;proc/pid/&nbsp;limits查看redis的进程对应的max&nbsp;open&nbsp;files依然为992,原因是centos6.2版本以下,已经运行的进程是无法修改limits的,但是centos6.2以上可以通过<br />
echo&nbsp;-n&nbsp;&lsquo;Max&nbsp;open&nbsp;files=65535:65535&rsquo;&nbsp;&gt;&nbsp;/proc/pid/&nbsp;limits命令,动态设置redis进程的最大连接数;正常情况下已经关闭客户端但没释放的ESTABLISHED&nbsp;off连接是清理不掉的,只能杀掉对应redis端口,数据会丢失,但是redis有封装好的方法CLIENT命令,能够实现三种功能:检查连接的状态,杀掉某个连接以及为连接设置名字三种功能,CLIENT&nbsp;LIST&nbsp;命令能够获取当前所有客户端的状态,CLIENT&nbsp;KILL&nbsp;命令来杀死指定的连接了,所以可以通过CLIENT&nbsp;KILL来杀掉没用但无法释放的tcp连接,处理掉redis连接数过多无法连接的问题。</p>

<hr />
<p>写了个程序,对redis连续进行100000访问,却出现以了Cannot assign requested address的问题,我起先是以为是redis的问题(可能承受不了这么多访问量),可是redis被大家吹的那么NB,不会出现这么SB的问题吧,</p>

<p>于是google之,发现原来是:客户端频繁的连服务器,由于每次连接都在很短的时间内结束,导致很多的TIME_WAIT,以至于用光了可用的端口号,所以新的连接没办法绑定端口,即&ldquo;Cannot assign requested address&rdquo;。</p>

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

<p>从网上找了解决办法:执行命令修改如下2个内核参数:</p>

<h5>sysctl -w net.ipv4.tcp_timestamps=1</h5>

<p>开启对于TCP时间戳的支持,若该项设置为0,则下面一项设置不起作用</p>

<h5>sysctl -w net.ipv4.tcp_tw_recycle=1</h5>

<p>表示开启TCP连接中TIME-WAIT sockets的快速回收。</p>

<p>不过好像只有root用户才能有修改这两个参数的权限,我正好有机器的root权限,修改之,发现,还真可以。</p>

<p>但是如果没有root权限怎么解决,能不能通过修改程序获得就不知道了。希望高人看到后指点一下!</p>

<hr />
<h1><a href="http://www.cnblogs.com/tinywan/p/6080293.html" id="cb_post_title_url">Redis高级实践之&mdash;&mdash;&mdash;&mdash;Redis短连接性能优化</a></h1>

<p>原文地址:http://www.cnblogs.com/tinywan/p/6080293.html#3811743,注意:这篇文章要修改redis源代码。</p>
页: [1]
查看完整版本: 处理redis连接数过多[综合处理]?