Redis 简易消息队列

为了保持程序的高效,建议使用ProtoBuf.

Google Protocol Buffer( 简称 Protobuf) 是 Google 公司内部的混合语言数据标准,目前已经正在使用的有超过 48,162 种报文格式定义和超过 12,183 个 .proto 文件。他们用于 RPC 系统和持续数据存储系统。

Protocol Buffers 是一种轻便高效的结构化数据存储格式,可以用于结构化数据串行化,或者说序列化。

Net中使用也很简单,在NuGet 获取,使用特性标记即可,有点类似wcf中的契约.

    [ProtoContract]
    public class TestQuene
    {

        [ProtoMember(1)]
        public int Id
        {
            get;
            set;
        }

简单的队列队列入队与出队测试,效果还不错.

       for (int i = 0; i < 100; i++)
            {
                MemoryStream xmlw = new MemoryStream();
                TestQuene TempTest = new TestQuene() { Id = i, data = new List<string>(new string[] { "1", "2", "3" }) };
                Serializer.Serialize<TestQuene>(xmlw, TempTest);
                message = Convert.ToBase64String(xmlw.ToArray());
                Console.WriteLine("EnqueueItemOnList=" + message);
                redis.EnqueueItemOnList("MessageQuene", message);
            }
      ThreadPool.UnsafeQueueUserWorkItem(o =>
            {
                while (true)
                {
                    try
                    {
                        MemoryStream ms = new MemoryStream(Convert.FromBase64String(redis.BlockingPopItemFromList("MessageQuene", TimeSpan.FromHours(2))));

                        Console.WriteLine("while=" + Serializer.Deserialize<TestQuene>(ms));
                    }
                    catch (Exception ex)
                    {
                        Debug.WriteLine(ex.ToString());
                    }
                }
            }, null);

 

posted @ 2016-07-02 08:35  欣欣点灯  阅读(336)  评论(0编辑  收藏  举报