redis實現簡單隊列_Redis

來源:互聯網
上載者:User

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

以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支援雲棲社區。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.