用redis实现简单的队列
2018-06-17 19:15:54来源:未知 阅读 ()
在工作中,时常会有用到队列的场景,比较常见的用rabbitMQ这些专业的组件,官网地址是:http://www.rabbitmq.com,重要的是官方有.net的客户端,但是如果对rabbitMQ不熟悉的话,建议使用第三方封装好的 EasyNetQ,rabbitMQ比较适合对安全性,稳定性要求较高的地方,但有时我们也会有对这方面要求不是很高的场景,比如:文章阅读数,实时性要求不是很高的地方,所以我想到了用redis来做队列。
redis 的List结构本身就是一个链表 (双向链表),所以符合我们的队列先进先出的要求。
我用的是StackExchange.Redis 这个组件来操作redis,以前一直用 Service.Stack.Redis,后来该类库升级后对个人使用有次数限制,需要付费使用才能没有调用限制.
操作redis简单封装如下:
public static class RedisHelper { public static int i = 0; private static string redisConnectionString = ConfigurationManager.AppSettings["RedisConnectionString"].ToString(); private static Lazy<ConnectionMultiplexer> lazyConnection = new Lazy<ConnectionMultiplexer>(() => { i++; return ConnectionMultiplexer.Connect(redisConnectionString); }); public static ConnectionMultiplexer Instance { get { return lazyConnection.Value; } } }
有了这个操作类后,我们就可以操作redis了,简单的对 list 的操作如下:
/// <summary> /// 简单 redis 队列 /// </summary> public class SimpleRedisQueue { public void LeftPush(string key, string value) { var redis = RedisHelper.Instance.GetDatabase(); redis.ListLeftPush(key, value); } public string RightPop(string key) { var redis = RedisHelper.Instance.GetDatabase(); return redis.ListRightPop(key); } }
测试代码如下:
首先需要一个生产数据的程序
static void Main(string[] args) { System.Threading.Tasks.Task.Factory.StartNew(() => { for (var i = 0; i < 99999999; i++) { new WLX.SimpleUtil.Redis.SimpleRedisQueue().LeftPush("test1", "a_" + i.ToString()); } }); System.Threading.Tasks.Task.Factory.StartNew(() => { for (var i = 0; i < 99999999; i++) { new WLX.SimpleUtil.Redis.SimpleRedisQueue().LeftPush("test1", "b_" + i.ToString()); } }); System.Threading.Tasks.Task.Factory.StartNew(() => { for (var i = 0; i < 9999; i++) { new WLX.SimpleUtil.Redis.SimpleRedisQueue().LeftPush("test1", "c_" + i.ToString()); } }); System.Threading.Tasks.Task.Factory.StartNew(() => { for (var i = 0; i < 99999999; i++) { new WLX.SimpleUtil.Redis.SimpleRedisQueue().LeftPush("test1", "e_" + i.ToString()); } }); System.Threading.Tasks.Task.Factory.StartNew(() => { for (var i = 0; i < 99999999; i++) { new WLX.SimpleUtil.Redis.SimpleRedisQueue().LeftPush("test1", "f_" + i.ToString()); } }); Console.ReadKey(); }
然后有消费队列的程序:
static void Main(string[] args) { var queue = new SimpleRedisQueue(); while (true) { var v = queue.RightPop("test1"); Console.WriteLine(v == null ? "空" : v); } }
测试结果截图
对可靠性和稳定性要求不高的应用场景,可以使用redis简单方便的实现。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- Delphi - 手把手教你基于D7+Access常用管理系统架构的设计与 2019-12-11
- Delphi - Server Monitor开发并实现指定端口定时刷新、重启 2019-12-09
- Delphi - 利用TRzTrayIcon实现WinFrm工程最小会到托盘 2019-09-04
- Delphi - 互斥对象下实现系统的单例模式 2019-09-04
- Delphi - Indy TIdMessage和TIdSMTP实现邮件的发送 2019-08-29
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash