赞
踩
redis.clients.jedis.exceptions.JedisAskDataException
异常是在使用 Jedis 客户端与 Redis 集群交互时遇到的一种重定向异常。这种异常表明客户端尝试在一个 Redis 集群节点上执行一个操作,但这个操作的数据并不在该节点上,而是存在于集群的另一个节点上。与 JedisMovedDataException
不同的是,JedisAskDataException
通常发生在涉及多个键(keys)的操作中,其中一个或多个键的数据位于当前节点之外的节点上。
在 Redis 集群中,每个键都被哈希到一个特定的哈希槽(hash slot),并且每个哈希槽都被分配给一个或多个 Redis 节点。当客户端尝试执行一个涉及多个键的操作(如 MGET、MSET 等),而这些键分布在不同的哈希槽上时,操作就会失败,并可能触发 JedisAskDataException
异常。因为 Redis 集群要求所有键都属于同一个哈希槽,以便在一个节点上原子性地执行这些操作。
解决 JedisAskDataException
的思路是让 Jedis 客户端自动处理重定向逻辑。使用 JedisCluster
而不是 Jedis
是处理这种情况的正确方法,因为 JedisCluster
内部会处理这些重定向,并尝试在正确的节点上重新执行操作。
当与 Redis 集群交互时,应始终使用 JedisCluster
而不是 Jedis
。JedisCluster
会自动处理哈希槽和重定向,你不需要关心这些细节。
下滑查看解决方法
代码示例:
Set<HostAndPort> jedisClusterNodes = new HashSet<HostAndPort>();
jedisClusterNodes.add(new HostAndPort("127.0.0.1", 7000));
jedisClusterNodes.add(new HostAndPort("127.0.0.1", 7001));
// ... 添加其他节点
JedisCluster jedisCluster = new JedisCluster(jedisClusterNodes);
try {
// 执行涉及多个键的操作,例如 MGET
List<String> values = jedisCluster.mget("key1", "key2", "key3");
// ... 执行其他操作
} finally {
if (jedisCluster != null) {
jedisCluster.close();
}
}
在这个示例中,即使 key1
、key2
和 key3
分布在不同的 Redis 节点上,JedisCluster
也会自动处理重定向,并在正确的节点上执行 MGET
操作。
虽然可以通过重新设计你的数据模型或操作来避免涉及多个哈希槽的操作(即将相关的键存储在同一个哈希槽中),但这通常不是一种可行的解决方案,因为它会限制你的数据模型和操作灵活性。此外,它也可能导致哈希槽之间的数据不均衡,从而影响 Redis 集群的性能和可靠性。因此,这种方法通常不推荐使用。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。