本次主要分享一下使用redis做缓存队列,实现生产者消费者模式。

  首先先来看一下redis提供的列表操作接口。像ListRightPush就和符合队列先进先出的原则。

  然后围绕这个列表已下单为例简要实现生产者和消费者两端的模块。

  生产者Controller

     IApplicationContext ctx = ContextRegistry.GetContext();
/// <summary>
///
/// </summary>
public void Order()
{
OrderRequest order = new OrderRequest { Mobile = "", GoodsName = "抱枕", Price = , OrderId = "" };
Thread t1 = new Thread(new ParameterizedThreadStart(WriteQueue));
t1.Start(order);
order = new OrderRequest { Mobile = "", GoodsName = "坚果", Price = , OrderId = "" };
Thread t2 = new Thread(new ParameterizedThreadStart(WriteQueue));
t2.Start(order);
order = new OrderRequest { Mobile = "", GoodsName = "羽绒服", Price = , OrderId = "" };
Thread t3 = new Thread(new ParameterizedThreadStart(WriteQueue));
t3.Start(order);
order = new OrderRequest { Mobile = "", GoodsName = "阔腿裤", Price = , OrderId = "" };
Thread t4 = new Thread(new ParameterizedThreadStart(WriteQueue));
t4.Start(order);
order = new OrderRequest { Mobile = "", GoodsName = "芒果", Price = , OrderId = "" };
Thread t5 = new Thread(new ParameterizedThreadStart(WriteQueue));
t5.Start(order);
order = new OrderRequest { Mobile = "", GoodsName = "哑铃", Price = , OrderId = "" };
Thread t6 = new Thread(new ParameterizedThreadStart(WriteQueue));
t6.Start(order);
}
/// <summary>
///
/// </summary>
/// <param name="obj"></param>
private void WriteQueue(Object obj)
{
//通过spring容器创建对象
IBLLQueue BLLQueue = ctx.GetObject<BLLQueue>("IBLLQueue");
BLLQueue.WriteRedisQueue((OrderRequest)obj);
}
    /// <summary>
/// 订单对象
/// </summary>
  public class OrderRequest
    {
/// <summary>
/// 订单Id
/// </summary>
public string OrderId { get; set; }
/// <summary>
/// 手机
/// </summary>
public string Mobile { get; set; }
/// <summary>
/// 物品名称
/// </summary>
public string GoodsName { get; set; }
/// <summary>
/// 价格
/// </summary>
public double Price { get; set; }
}

  接口和实现类

   public interface IBLLQueue
{
/// <summary>
///
/// </summary>
/// <returns></returns>
void WriteRedisQueue(OrderRequest order);
} public class BLLQueue : IBLLQueue
{
private string key = "OrderQueue";
readonly static object _locker = new object();
/// <summary>
///
/// </summary>
/// <param name="WriteRedisQueue"></param>
public void WriteRedisQueue(OrderRequest order)
{
//添加到下单队列
lock (_locker)
{
var json = JsonHelper.SerializeObject(order);
var result = (int)RedisService.ListRightSet(key, json);
}
}
}

  redis帮助类

        /// <summary>
/// ListGet
/// </summary>
/// <param name="key"></param>
/// <returns></returns>
public static RedisValue[] ListGet(string key)
{
return Db.ListRange(key);
}
/// <summary>
/// ListSet(尾)
/// </summary>
/// <param name="key"></param>
/// <param name="value"></param>
/// <returns></returns>
public static long ListRightSet(string key, string value)
{
return Db.ListRightPush(key, value);
}
/// <summary>
/// ListSet(头)
/// </summary>
/// <param name="key"></param>
/// <param name="value"></param>
/// <returns></returns>
public static long ListLeftSet(string key, string value)
{
return Db.ListLeftPush(key, value);
}
/// <summary>
/// ListRemove
/// </summary>
/// <param name="key"></param>
/// <param name="value"></param>
/// <returns></returns>
public static long ListRemove(string key, string value)
{
return Db.ListRemove(key, value);
}
/// <summary>
/// ListLength
/// </summary>
/// <param name="key"></param>
/// <param name="value"></param>
/// <returns></returns>
public static long ListLength(string key)
{
return Db.ListLength(key);
}

  运行方法,通过可视化工具可看到redis列表结果:

  2.通过控制台输出程序简单实现消费者模块。

  main函数:

      static void Main(string[] args)
{
Queue queue = new Queue();
queue.run();
}

  订单消费者实现方法:

 public class Queue
{
private string key = "OrderQueue";
private bool flg = true;
readonly static object _locker = new object();
public void run()
{
try
{
lock (_locker)
{
while (flg)
{
if (RedisService.ListLength(key) > )
{
Take();
}
flg = false;
}
}
}
catch (Exception ex)
{
Console.WriteLine(ex.Message);
}
}
public void Take()
{
var list = RedisService.ListGet(key).ToList();
foreach (var item in list)
{
var order = JsonHelper.DeserializeJsonToObject<OrderRequest>(item);
if (order != null)
{
Console.WriteLine("订单编号:" + (order.OrderId ?? "") + " 物品名称:" + (order.GoodsName ?? "") + " 手机:" + (order.Mobile ?? "") + " 价格:" + order.Price);
}
//移除队列
RedisService.ListRemove(key, item);
}
}
}

  执行结果:

  这样本次的案例就算小功告成。这边有简单使用spring.net。以前有使用过spring,年代久远,目前自己正在重新学习当中,往后再分享这一块学习心得。

使用redis实现生产者消费者模式的更多相关文章

  1. Celery 框架学习笔记(生产者消费者模式)

    生产者消费者模式 在实际的软件开发过程中,经常会碰到如下场景:某个模块负责产生数据,这些数据由另一个模块来负责处理(此处的模块是广义的,可以是类.函数.线程.进程等).产生数据的模块,就形象地称为生产 ...

  2. day 28 :进程相关,进程池,锁,队列,生产者消费者模式

    ---恢复内容开始--- 前情提要: 一:进程Process  1:模块介绍 from multiprocessing import Process from multiprocessing impo ...

  3. 第三节: List类型的介绍、生产者消费者模式、发布订阅模式

    一. List类型基础 1.介绍 它是一个双向链表,支持左进.左出.右进.右出,所以它即可以充当队列使用,也可以充当栈使用. (1). 队列:先进先出, 可以利用List左进右出,或者右进左出(Lis ...

  4. java多线程 生产者消费者模式

    package de.bvb; /** * 生产者消费者模式 * 通过 wait() 和 notify() 通信方法实现 * */ public class Test1 { public static ...

  5. LabVIEW之生产者/消费者模式--队列操作 彭会锋

    LabVIEW之生产者/消费者模式--队列操作 彭会锋 本文章主要是对学习LabVIEW之生产者/消费者模式的学习笔记,其中涉及到同步控制技术-队列.事件.状态机.生产者-消费者模式,这几种技术在在本 ...

  6. 转:Task任务调度实现生产者消费者模式 (个人理解后文)

    纯属个人愚见.欢迎加入反驳(PiDou). 1.前文大致就是,利用Queue配置的一个TaskFactory任务调度器.实现生产者消费者模式的例子..首先我就试了 第一种 FIFO(先进先出)的配置. ...

  7. Lucene.net站内搜索—4、搜索引擎第一版技术储备(简单介绍Log4Net、生产者消费者模式)

    目录 Lucene.net站内搜索—1.SEO优化 Lucene.net站内搜索—2.Lucene.Net简介和分词Lucene.net站内搜索—3.最简单搜索引擎代码Lucene.net站内搜索—4 ...

  8. MVC异常日志生产者消费者模式记录(异常过滤器)

    生产者消费者模式 定义自己的异常过滤器并注册 namespace Eco.Web.App.Models { public class MyExceptionAttribute : HandleErro ...

  9. 转:Task任务调度实现生产者消费者模式

    我们经常会遇到生产者消费者模式,比如前端各种UI操作事件触发后台逻辑等.在这种典型的应用场景中,我们可能会有4个业务处理逻辑(下文以P代表生产者,C代表消费者): 1. FIFO(先进先出)      ...

随机推荐

  1. GitHub Flow & Git Flow 基于Git 的两种协作开发模式

    介绍基于Git 两种协作开发模式,GitHub Flow & Git Flow 对于Github 一些好用的特殊操作技巧 ,可以见GitHub 特殊操作技巧 和Git的基本操作 一 GitHu ...

  2. PyCharm 专业版激活方法

    郑重声明: JetBrains公司的PyCharm专业版是收费的,本文所述激活方法仅限于短时内体验和试用PyCharm专业版,使用后请当天立即删除.若需要继续使用PyCharm专业版,请在官网购买.当 ...

  3. SQL Server的优化器会缓存标量子查询结果集吗

    在这篇博客"ORACLE当中自定义函数性优化浅析"中,我们介绍了通过标量子查询缓存来优化函数性能: 标量子查询缓存(scalar subquery caching)会通过缓存结果减 ...

  4. java笔记----JVM内存

    运行时数据区包括:虚拟机栈区,堆区,方法区,本地方法栈,程序计数器 虚拟机栈区 :也就是我们常说的栈区,线程私有,存放基本类型,对象的引用和 returnAddress ,在编译期间完成分配. 堆区  ...

  5. javascript中(function($){...})(jQuery)写法是什么意思

    这里实际上是匿名函数function(arg){...}这就定义了一个匿名函数,参数为arg 而调用函数 时,是在函数后面写上括号和实参的,由于操作符的优先级,函数本身也需要用括号,即:(functi ...

  6. python高级(2)—— 基础回顾2

    回顾知识 一 操作系统的作用: 隐藏丑陋复杂的硬件接口,提供良好的抽象接口 管理.调度进程,并且将多个进程对硬件的竞争变得有序 关于操作系统的发展史,可以参考我之前的一篇博文:传送门 二 多道技术: ...

  7. c/c++ 模板与STL小例子系列<三> traits

    c/c++ 模板与STL小例子系列 traits 对这个概念,还是处于懵逼的状态,初步体会就是,为了解决类型之间的转换问题. 从一个类型为A的指针,转化到类型为B的指针,中间需要用void*来作为中介 ...

  8. [Hive_8] Hive 设计优化

    0. 说明 在 Hive 中,数据库是一个文件夹,表也是文件夹 partition,是一个字段,是文件 前提:在 Hive 进行 where 子句查询的时候,会将条件语句和全表进行比对,搜索出所需的数 ...

  9. 【ZJOI2016】线段树

    [ZJOI2016]线段树 ZJOI的题神啊. 我们考虑计算每个位置\(p\),它在操作过后变成第\(x\)个数的操作序列数. 我们枚举\(x\).我们先得到了\(L_x,R_x\)表示最左边比\(x ...

  10. 文件IO模型

    In case of kernel-space network drivers, all three regions are mapped to kernel space, and any acces ...