0

这是使用 stackexchange.redis v1.1.603、.net 4.6、控制台应用程序。这是我的代码:

using System;
using System.Collections.Generic;
using StackExchange.Redis;

namespace RedisClusterTesting
{
    class Program
    {
        static void Main(string[] args)
        {
            string ip = "192.168.1.20:30001,192.168.1.20:30002,192.168.1.20:30003,resolvedns=1";
            var conf = ConfigurationOptions.Parse(ip);
            conf.CommandMap = CommandMap.Create(new HashSet<string> {
                "INFO", "CONFIG", "CLUSTER","PING", "ECHO", "CLIENT"
            }, false);
            using (ConnectionMultiplexer conn = ConnectionMultiplexer.Connect(conf))
            {
                var db = conn.GetDatabase();
                Do(db);
            }
            Console.ReadKey();
        }
        private static void Do(IDatabase db)
        {
            /*here throws MOVED Exception:MOVED 12182 192.168.1.20:30003*/
            db.StringSet("foo", "changed");
            Console.WriteLine("foo now:" + db.StringGet("foo").ToString());
        }
    }
}

始终显示消息“已移动:12586 [192.168.1.20:30003]”。

我搜索了所有的官方文档和互联网,找不到正确的答案。我使用 redis-cli 时没关系。

如何解决这个问题?我需要在我的代码中处理异常吗?如果,如何?

4

1 回答 1

1

似乎您可能遇到了这个问题:https ://github.com/StackExchange/StackExchange.Redis/issues/248 。如果您在 Connect() 调用和 Do() 调用之间放置 1 秒睡眠,我猜您会看到问题消失。

于 2016-06-13T23:28:11.830 回答