我正在尝试基于 BookSleeve组合一个超级简单的排队示例。
到目前为止,这是队列消费者方面的内容:
using System;
using System.Text;
using BookSleeve;
static class Program
{
static void Main()
{
using (var redis = new RedisConnection("127.0.0.1"))
{
redis.Open();
while (true)
{
// BRPOP the queue
var t = redis.Lists.BlockingRemoveFirst(0, new[] { "test" }, 0);
t.Wait();
var val = Encoding.UTF8.GetString(t.Result.Item2);
Console.WriteLine("Got: {0}", val);
}
}
}
}
我作为生产者在LINQPad中运行以下命令:
using(var redis = new RedisConnection("localhost"))
{
redis.Open();
foreach(var i in Enumerable.Range(0, 10))
{
// LPUSH
redis.Lists.AddFirst(0, "test", "foo" + i)
// Call wait to keep things in order
.Wait();
}
Thread.Sleep(500); // Let Redis do it's thing
Console.WriteLine("queue length: " + redis.Lists.GetLength(0, "test").Result);
}
我得到了一些非常奇怪的结果:
第一次运行:
Got: foo2
Got: foo5
Got: foo7
Got: foo9
第二次运行:
Got: foo1
Got: foo4
Got: foo7
第三次运行:
Got: foo0
Got: foo3
Got: foo6
Got: foo8
此外,每次运行后,LINQPad 都会输出:queue length: 0
,并且LLEN test
使用实际的 redis 客户端运行会返回(integer) 0
。
我不禁觉得我在这里遗漏了一些东西,很可能与异步的东西有关,但我就是看不到。
我的redis版本是2.8.3,BookSleeve版本是1.3.41。
这里的实际问题是:为什么 BookSleeve 只返回发送到 redis 列表的消息的子集?