书架过早关闭连接?

时间:2013-03-28 14:16:36

标签: c# booksleeve

我在VS2010中使用1.1.0.5版本的Booksleeve时遇到了困难,我打算使用它。发生的事情是在执行并等待操作之后,Booksleeve有时会将连接保持在关闭状态,因此下游操作会抛出异常。

我遇到的最简单的问题是:

static void Main(string[] args)
{
     Func<RedisConnection> getNewRedisConnection = () =>
        {
            RedisConnection conn = new RedisConnection("Belasco");
            conn.Error += (obj, eArgs) => { throw eArgs.Exception; };
            return conn;
        };

    RedisConnection redisConn = null;
    TaskScheduler.UnobservedTaskException += new EventHandler<UnobservedTaskExceptionEventArgs>(TaskScheduler_UnobservedTaskException);

    redisConn = getNewRedisConnection();
    redisConn.Open();

    var test1 = redisConn.Sets.GetAllString(0, "test1");
    var testValues1 = test1.Result;
    //var testValues1 = redisConn.Wait(test1);

    var test2 = redisConn.Sets.GetAllString(0, "test2");
    var testValues2 = test2.Result;
    //var testValues2 = redisConn.Wait(test2);

    redisConn.Close(false);

    Console.WriteLine("Done");
    Console.ReadKey();
}

static void TaskScheduler_UnobservedTaskException(object sender, UnobservedTaskExceptionEventArgs e)
{
    throw new NotImplementedException();
}

var test2 = redisConn.Sets.GetAllString(0, "test2");抛出'队列已关闭'异常。

现在,如果我关闭并重新打开请求之间的连接,那么事情似乎有效。

    var test1 = redisConn.Sets.GetAllString(0, "test1");
    var testValues1 = test1.Result;
    //var testValues1 = redisConn.Wait(test1);

    redisConn.Close(false);
    redisConn = getNewRedisConnection();
    redisConn.Open();

    var test2 = redisConn.Sets.GetAllString(0, "test2");
    var testValues2 = test2.Result;
    //var testValues2 = redisConn.Wait(test2);

然而,如果我执行“设置”操作,所有似乎都会重新开始。

    redisConn = getNewRedisConnection();
    redisConn.Open();

    var test0 = redisConn.Sets.Add(0, "test1", new string[] { "11", "22", "33", "44", "55" });
    redisConn.Wait(test0);

    redisConn.Close(false);
    redisConn = getNewRedisConnection();
    redisConn.Open();

    var test1 = redisConn.Sets.GetAllString(0, "test1");
    var testValues1 = test1.Result;
    //var testValues1 = redisConn.Wait(test1);

    redisConn.Close(false);
    redisConn = getNewRedisConnection();
    redisConn.Open();

    var test2 = redisConn.Sets.GetAllString(0, "test2");
    var testValues2 = test2.Result;
    //var testValues2 = redisConn.Wait(test2);

我对交易也有同样的问题,但我觉得它源于同一个问题。我需要检索值,然后排队另一个命令的原因是因为我后来使用Redis的操作是根据我得到的值确定的!

1 个答案:

答案 0 :(得分:0)

首先,不要急切关闭连接离子。 BookSleeve旨在用作线程安全的多路复用器,同时从任意随机数的呼叫者处获取负载。打开连接有开销。现在,红色连接有几种方法可以关闭:

  • 你选择性地关闭它
  • 服务器关闭它(连接超时,客户端无法处理积压)
  • 客户端检测到它不期望的入站流中的内容

我的猜测是服务器配置了连接超时。我不知道1.1。*,但是在某些时候添加了自动超时配置检测和保持活动的“ping”消息,这有所帮助。您可以通过redis-cli中的“config get timeout”检查超时。如果这是问题,您可能会发现升级客户端版本有帮助。在某些版本中,您还可以手动指定超时配置(如果要覆盖服务器)。

对于意外数据 - 这是不太可能的,但是有一些事件你可以挂钩来检测,记录并对此作出反应。