首页 > 其他 > 详细

Redis 简易消息队列

时间:2016-07-02 09:08:52      阅读:199      评论:0      收藏:0      [点我收藏+]

为了保持程序的高效,建议使用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);

 

Redis 简易消息队列

原文:http://www.cnblogs.com/CoreXin/p/Redis.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!