redis连接数合理配置_Redis连接数不释放,可修改相关配置参数

工作中,曾遇到redis连接数一直不释放,导致请求阻塞甚至挂掉的问题。重启redis后,短暂性恢复正常,过一会又会异常。后来查阅相关文档了解到,对于此异常现象可以参考通过修改配置参数解决。

timeout 是指客户端和Redis服务端的连接超时时间,默认是0,表示永不超时;

tcp-keepalive 如果值非0,单位是秒,表示将周期性的使用SO_KEEPALIVE检测客户端是否还处于健康状态,避免服务器一直阻塞,官方给出的建议值是60。

一般同类现象产生的原因有多种,这里只是给出参考,并不是标准答案,以下是redis相关参数说明。

属性

说明

daemonize

如果值是“yes”,则启动服务的时候是后台守护进程形式,如果值是“no”,则相反

pidfile

指定存储Redis进程号的文件路径

port

指定当前Redis服务的端口,默认为6379

tcp-backlog

此参数确定了TCP连接中已完成队列(完成三次握手之后)的长度, 当然此值必须不大于Linux系统定义的/proc/sys/net/core/somaxconn值,默认是511,而Linux的默认参数值是128。当系统并发量大并且客户端速度缓慢的时候,可以将这二个参数一起参考设定。

timeout

客户端和Redis服务端的连接超时时间,默认是0,表示永不超时。

tcp-keepalive

如果值非0,单位是秒,表示将周期性的使用SO_KEEPALIVE检测

你可能感兴趣的:(redis连接数合理配置)