上午午好好的,突然抛了如下异常:
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)
后来登录客户端后如下:
这说明redis集群已经宕机了。下面分析一下造成的原因。该引用来自(http://hot66hot.iteye.com/blog/2050676)
redis-cluster选举:容错
(1)领着选举过程是集群中所有master参与,如果半数以上master节点与master节点通信超过(cluster-node-timeout),认为当前master节点挂掉.
(2):什么时候整个集群不可用(cluster_state:fail)?
a:如果集群任意master挂掉,且当前master没有slave.集群进入fail状态,也可以理解成集群的slot映射[0-16383]不完成 时进入fail状态. ps : redis-3.0.0.rc1加入cluster-require-full-coverage参数,默认关闭,打开集群兼容部分失败.
b:如果集群超过半数以上master挂掉,无论是否有slave集群进入fail状态.
ps:当集群不可用时,所有对集群的操作做都不可用,收到((error) CLUSTERDOWN The cluster is down)错误
后来集群好了之后,还是报错,最后经过查找代码终于发现是调用JedisCluster.close()方法造成的。
结论:JedisCluster.close()方法造成的集群连接关闭的情况。
经研究发现jedisCluster内部使用了池化技术,每次使用完毕都会自动释放Jedis因此不需要关闭。
http://www.cnblogs.com/zhangshiwen/p/5808820.html
相关推荐
报错信息: no reachable node in cluster 原因:创建集群时,使用了127.0.0.1,要改为公网ip才行。 redis-cli –cluster create 127.0.0.1:7001 127.0.0.1:7002 解决方法:改为 redis-cli --cluster create 公网ip:...
在SpringCloud框架中,部署Redis集群是实现高可用、数据持久化和分布式缓存的关键步骤。Redis是一款高性能的键值数据库,广泛应用于缓存、消息队列等多种场景。SpringCloud通过集成Spring Data Redis模块,使得在...
如果出现异常,程序会捕获并打印错误信息,最后记得关闭JedisCluster连接以释放资源。 为了更好地理解和优化代码,可以下载提供的源码进行查看。源码中可能包含了更复杂的逻辑,如错误处理、连接池管理等。同时,...
2. 初始化JedisCluster:在Java代码中,我们需要创建一个JedisCluster对象,传入Redis集群的节点信息。这里以公网IP为例: ```java Set<HostAndPort> nodes = new HashSet(); nodes.add(new HostAndPort("公网IP...
在Spring Boot 2.1及以上版本中,我们可以利用`spring.redis.cluster.nodes`属性来实现零配置连接到Redis集群,只需将所有集群节点的IP和端口以逗号分隔的形式列出即可,如: ```properties spring.redis.cluster....
k8s集群搭建redis集群 k8s集群搭建redis集群 k8s集群搭建redis集群 k8s集群搭建redis集群 k8s集群搭建redis集群
实际迁移过程中,我们以两个场景为例:一是从一个Redis集群(Cluster_A)迁移到另一个Redis集群(Cluster_B),二是从Redis集群(Cluster_A)迁移到单个Redis实例(Redis_C)。在迁移前,务必先检查源和目标Redis...
在使用redis集群时,发现过期key始终监听不到。网上也没有现成的解决方案。于是想,既然不能监听集群,那我可以建立多个redis连接,分别对每个redis的key过期进行监听。以上做法可能不尽人意,目前也没找到好的解决...
这些参数包括redis.database、redis.timeout、redis.password、redis.cluster.max-redirects、redis.cluster.nodes等。这些参数的配置将影响Redis集群的行为和性能。 ### 第三步:注册配置 在SpringBoot 2.X中,...
使用`redis-cli`工具进行集群初始化,执行`redis-cli --cluster create node1_ip:port node2_ip:port ... --cluster-replicas 1`命令,其中`node_ip:port`是各个节点的地址,`--cluster-replicas 1`表示每个主节点...
1. **节点(Node)**:每个运行Redis服务器的实例就是一个节点,它们共同构成集群。 2. **槽(Slot)**:集群将数据空间划分为16384个槽,每个键映射到一个槽,以确定其存储在哪个节点。 3. **客户端(Client)**:...
Spring框架提供了`spring-data-redis`模块,其中包含`JedisCluster`和`RedisClusterTemplate`等类用于支持Redis集群。在Spring配置文件中,我们需要定义`ConnectionFactory`,通常使用`JedisConnectionFactory`,并...
使用redis安装用户,在命令行连接上redis集群后,执行命令:config set requirepass 【自定义的强密码】,如: config set requirepass mypassword@#75@~ 然后执行 config rewrite 将配置密码持久化到redis配置文件...
项目由maven构建,使用springMVC整合了Redis的集群,发布到tomcat中,访问http://localhost:8080/SpringRedisCluster/redis/hello.do测试即可,前提是配好了redis的集群。
1. **节点(Node)**:Redis集群由多个节点组成,每个节点都是一个独立运行的Redis服务器。 2. **槽(Slot)**:为了实现数据分片,Redis集群将数据库的键空间划分为16384个槽。每个键属于且仅属于一个槽。 3. **...
本文将深入探讨如何使用Spring Data Redis构建一个Redis集群,以及如何通过Spring框架来操作Redis集群,存储对象集合,并提供一个基于Maven的可运行项目示例。 首先,Spring Data Redis是Spring框架的一个模块,它...
3. **判断异常**:根据预设阈值判断是否出现异常,例如,如果节点状态为`down`或复制丢失,就认为是异常。 4. **发送邮件**:如果检测到异常,使用`mail`或`mutt`等工具,将异常信息和相关日志发送给管理员。 5. **...
9. **edu-demo-redis-cluster**:这可能是具体实现Redis集群功能的示例项目,可能包含配置文件、Java代码或者其他脚本,用于演示如何在实际应用中设置和使用Redis集群。 在实际测试过程中,开发者需要确保集群的...
3. 一旦集群创建成功,你就可以使用 Ruby 的 Redis 集群客户端(如 `redis-cluster` gem)与集群交互。首先,需要安装这个 gem: ```bash gem install redis-cluster ``` 4. 然后,使用以下代码连接到集群: ```ruby...