这篇文章给大家分享的是有关Jedis使用中常见的客户端异常情况有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、无法从连接池获取到连接JedisPool中的Jedis对象个数是有限的,默认是8个。这里假设使用的默认配置,如果有8个Jedis对象被占用,并且没有归还,如果调用者还要从JedisPool中借用Jedis,就需要进行等待(例如设置了maxWaitMillis>0),如果在maxWaitMillis时间内仍然无法获取到Jedis对象就会抛出如下异常。还有一种情况,就是设置了blockWhenExhausted=false,那么调用者发现池子中没有资源时,会立即抛出异常不进行等待,下面的异常就是blockWhenExhausted=false时的效果。对于这个问题,需要重点讨论的是为什么连接池没有资源了,造成没有资源的可能的原因非常多1.客户端:高并发下连接池设置过小,出现供不应求,所以会出现上面的错误,但是正常情况下只要比默认的最大连接数(8个)多一些即可,因为正常情况下JedisPool以及Jedis的处理效率足够高。2.客户端:没有正确使用连接池,比如没有进行释放,例如下面代码所示:定义JedisPool,使用默认的连接池配置。当调用者再向连接池借用Jedis时(如下操作),就会抛出异常:jedisPool.getResource().ping();
3.客户端:存在慢查询操作,这些慢查询持有的Jedis对象归还速度会比较慢,造成池子满了。4.服务端:客户端是正常的,但是Redis服务端由于一些原因造成了客户端命令执行过程的阻塞,也会使得客户端抛出这种异常。可以看到造成这个异常的原因是多个方面的,不要被异常的表象所迷惑,而且并不存在万能钥匙能解决所有问题,开发和运维只能不断加强对于Redis的理解,顺藤摸瓜逐渐找到问题所在。二、 客户端读写超时Jedis在调用Redis时,如果出现了读写超时后,会出现下面的异常:造成该异常的原因也有以下几种:读写超时设置的过短。
命令本身就比较慢。
客户端与服务端网络不正常。
Redis自身发生阻塞。三、客户端连接超时Jedis在调用Redis时,如果出现了读写超时后,会出现下面的异常:造成该异常的原因也有以下几种:连接超时设置的过短。
Redis发生阻塞,造成tcp-backlog已满,造成新的连接失败。
客户端与服务端网络不正常。四、客户端缓冲区异常Jedis在调用Redis时,如果出现客户端数据流异常,会出现下面的异常。造成这个异常原因可能有如下几种:1.输出缓冲区满。例如将普通客户端的输出缓冲区设置为1M 1M 60:如果使用get命令获取一个bigkey(例如3M),就会出现这个异常。2.长时间闲置连接被服务端主动断开,可以查询timeout配置的设置以及自身连接池配置是否需要做空闲检测。3.不正常并发读写:Jedis对象同时被多个线程并发操作,可能会出现上述异常。五、Lua脚本正在执行如果Redis当前正在执行Lua脚本,并且超过了lua-time-limit,此时Jedis调用Redis时,会收到下面的异常。对于如何处理这类问题(Lua lua-time-limit配置之前章节已经介绍了)六、Redis正在加载持久化文件Jedis调用Redis时,如果Redis正在加载持久化文件,那么会收到下面的异常。七、Redis使用的内存超过maxmemory配置Jedis调用Redis执行写操作时,如果Redis的使用内存大于maxmemory的设置,会收到下面的异常,此时应该调整maxmemory并找到造成内存增长的原因(maxmemory之前章节已经介绍了)八、客户端连接数过大如果客户端连接数超过了maxclients,新申请的连接就会出现如下异常:此时新的客户端连接执行任何命令,返回结果都是如下:这个问题可能会比较棘手,因为此时无法执行Redis命令,一般来说可以从两个方面进行着手。1.客户端:如果maxclients参数不是免费云主机域名很小的话,应用方的客户端连接数基本不会超过maxclients,通常来看是由于应用方对于Redis客户端使用不当造成的。此时如果应用方是分布式结构的话,可以通过下线部分应用节点(例如占用连接较多的节点),使得Redis的连接数先降下来。从而让绝大部分节点可以正常运行,此时在再通过查找程序bug或者调整maxclients进行问题的修复。2.服务端:如果此时客户端无法处理,而当前Redis为高可用模式(例如Redis Sentinel和Redis Cluster),可以考虑将当前Redis做故障转移。此问题不存在确定的解决方式,但是无论从哪个方面进行处理,故障的快速恢复极为重要,当然更为重要的是找到问题的所在,否则一段时间后客户端连接数依然会超过maxclients。附赠GenericObjectPoolConfig的重要属性感谢各位的阅读!关于“Jedis使用中常见的客户端异常情况有哪些”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!
相关推荐: 利用FORCE_MATCHING_SIGNATURE捕获非绑定变量SQL
sql text 相近的sqlFORCE_MATCHING_SIGNA免费云主机域名TURE 相同 因此可以使用下面的语句查找没有绑定变量的SQL 相关推荐: 关于oracle 11g acs的一点总结:今天谈谈下面这几个参数对数据库性能和稳定性的影响: cu…
免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。