redisclient使⽤⼩结
原⽂发表在私⼈站点,现迁移到简书
本⽂记录了使⽤redis client的基本配置和连接超限的问题
客户端配置
java端的redis client使⽤的是jedis,他的连接池实现是基于Apache Commons Pool 2,配置也参考的GenericObjectPoolConfig,分别是minIdle,maxIdle,maxTotal,其中maxTotal包含了活跃和⾮活跃的连接总数timeout was reached
maximum total connections (maxTotal) includes both active and idle connections.
maximum idle connections (maxIdle) are connections that are ready to be used (but are currently unused).
另外timeout是在Jedis的构造函数⾥指定的,他同时指定了connectionTimeout(最⼤连接时间)和soTimeout(最⼤响应时间 )
服务端配置
客户端配置就上⾯⼏个,⽤起来还是挺简单的,但是⽤的过程中还是会遇到⼀些问题,⽐如ERR max number of clients reached,有可能会是以下⼏个原因:
1.连接数超过限制
redis server最⼤连接数的配置由maxclients决定,2.6以后的版本默认值是10000,如果设置的值超过了操作系统的最⼤值限制,则会在启动的时候给出提⽰
$ ./redis-server --maxclients 100000
[41422] 23 Jan 11:28:33.179 # Unable to set the max number of files limit to 100032 (Invalid argument), setting the max clients configuration to 10112.
2.timeo ut没有配置
⼀般情况下,超过10000的最⼤连接数是使⽤上的问题。⾸先redis服务端默认的timout配置的是0,即不会关闭连接,即便这个连接已经空闲很久,这时候如果客户端在重启前没有关闭连接或者说中间有防⽕墙之类的断开了连接,redis 服务端将会永久保留这些连接,这时候只要配置timeout即可
config get timeout ## 查看timeout配置
3.k eepa live的设置
除了timeout也还可以通过keepalive配置来解决,⽐如如果你的redis⾓⾊是sentinel,那么redis⾥的timeout的配置是不⽣效的。
这⾥的keepalive指的是TCP协议层的配置,他有三个参数影响:
tcp_keepalive_time default 7200 seconds
tcp_keepalive_probes default 9
tcp_keepalive_intvl default 75 seconds
连接超时公式为:
tcp_keepalive_time+tcp_keepalive_intvl*tcp_keepalive_probes=7895s=131.58min
这个时间还是挺久的,redis服务端在3.2版本已经以后,默认设置了tcp_keepalive_time为300秒(以前的版本默认为0,也就是不启⽤)
配置上这个参数之后,对于⼀些客户端没有正常关闭的场景也能及时的关闭
4.正确关闭客户端连接
另外说到客户端的正确配置,如果是使⽤Spring的话,只要配置下bean的destroy-method,在这⾥关闭连接池即可,如果没有⽤Spring,则要⾃⼰注册⼀个ShutdownHook
参考
2.Custom Configuration of TCP Socket Keep-Alive Timeouts
3.Redis Clients Handling
4.Sentinel最⼤连接数

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。