我是靠谱客的博主 任性缘分,最近开发中收集的这篇文章主要介绍redis集群:RedisCluster 出现redis.clients.jedis.exceptions.JedisConnectionException: no reachable node in错误信息问题分析问题解决,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

错误信息

Exception in thread "main" redis.clients.jedis.exceptions.JedisNoReachableClusterNodeException: No reachable node in cluster
    at redis.clients.jedis.JedisSlotBasedConnectionHandler.getConnection(JedisSlotBasedConnectionHandler.java:57)
    at redis.clients.jedis.JedisSlotBasedConnectionHandler.getConnectionFromSlot(JedisSlotBasedConnectionHandler.java:74)
    at redis.clients.jedis.JedisClusterCommand.runWithRetries(JedisClusterCommand.java:116)
    at redis.clients.jedis.JedisClusterCommand.run(JedisClusterCommand.java:31)
    at redis.clients.jedis.JedisCluster.set(JedisCluster.java:103)
    at com.java.example.redis.JedisClusterDemo.setTest(JedisClusterDemo.java:33)
    at com.java.example.redis.JedisClusterDemo.main(JedisClusterDemo.java:28)

问题分析

这个错误出现的很奇怪,在运行起服务前我测试过集群,是没有问题的,但是在实际的代码运行中出现了这个问题。从网上找到的方法与我的情况不符。

问题解决

经过调试发现,是JedisCluster.close()方法造成的。

我的代码是从单机版的Redis转变来的,所以在一开始是以只用Jedis.close()关闭连接,但是在redis3.0的集群,用jedis的JedisCluster.close()方法造成的集群连接关闭的情况。 jedisCluster内部使用了池化技术,每次使用完毕都会自动释放Jedis因此不需要关闭。如果调用close方法后再调用jedisCluster的api进行操作时就会出现如上错误。

最后

以上就是任性缘分为你收集整理的redis集群:RedisCluster 出现redis.clients.jedis.exceptions.JedisConnectionException: no reachable node in错误信息问题分析问题解决的全部内容,希望文章能够帮你解决redis集群:RedisCluster 出现redis.clients.jedis.exceptions.JedisConnectionException: no reachable node in错误信息问题分析问题解决所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(44)

评论列表共有 0 条评论

立即
投稿
返回
顶部