国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > Redis > 正文

redis實現簡單隊列

2020-10-28 21:38:47
字體:
來源:轉載
供稿:網友

在工作中,時常會有用到隊列的場景,比較常見的用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簡單方便的實現。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 友谊县| 吴桥县| 罗甸县| 洛宁县| 滨州市| 卢氏县| 县级市| 商城县| 万载县| 南昌县| 女性| 新和县| 开阳县| 抚顺县| 海原县| 旬邑县| 黔西| 彰化市| 嘉兴市| 萝北县| 宁海县| 鹰潭市| 广昌县| 洪泽县| 宁武县| 安平县| 绥德县| 武汉市| 疏附县| 永嘉县| 渭南市| 合肥市| 黔江区| 红河县| 临江市| 江门市| 陆良县| 文昌市| 临邑县| 三亚市| 海宁市|