AWS Redis Cluster MOVED错误使用redis节点库

AWS Redis Cluster MOVED Error using redis node library

我在 AWS 中创建了一个具有 2 个节点的 Redis MemoryDB 集群:

我使用 redis 节点库 v4.0.0 连接到它,如下所示:

import { createCluster } from 'redis';
(async () => {
    const REDIS_USERNAME = 'test-username';
    const REDIS_PASSWORD = 'test-pass';
    const cluster = createCluster({
        rootNodes: [
            {
                url: `rediss://node1.amazonaws.com:6379`,
            },
            {
                url: `rediss://node2.amazonaws.com:6379`,
            },
        ],
        defaults: {
            url: `rediss://cluster.amazonaws.com:6379`,
            username: REDIS_USERNAME,
            password: REDIS_PASSWORD,
        }
    });
    cluster.on('error', (err) => console.log('Redis Cluster Error', err));
    await cluster.connect();
    console.log('connected to cluster...');
    await cluster.set('key', 'value');
    const value = await cluster.get('key');
    console.log('Value', value);
    await cluster.disconnect();
})();

但有时我会收到错误 ReplyError: MOVED 12539 rediss://node2.amazonaws.com:6379 并且无法从键中获取值。

不知道是集群配置有问题还是使用redis节点库的代码有问题?

编辑: 我用 ioredis 库试过了,它可以工作,所以 redis 库有问题。

Node.js 版本: 16

Redis 服务器版本:6

我创建了一个 issue to redis library, so it's going to be solved soon with this PR