使用redis实现生产者消费者模式
本次主要分享一下使用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实现生产者消费者模式的更多相关文章
- Celery 框架学习笔记(生产者消费者模式)
生产者消费者模式 在实际的软件开发过程中,经常会碰到如下场景:某个模块负责产生数据,这些数据由另一个模块来负责处理(此处的模块是广义的,可以是类.函数.线程.进程等).产生数据的模块,就形象地称为生产 ...
- day 28 :进程相关,进程池,锁,队列,生产者消费者模式
---恢复内容开始--- 前情提要: 一:进程Process 1:模块介绍 from multiprocessing import Process from multiprocessing impo ...
- 第三节: List类型的介绍、生产者消费者模式、发布订阅模式
一. List类型基础 1.介绍 它是一个双向链表,支持左进.左出.右进.右出,所以它即可以充当队列使用,也可以充当栈使用. (1). 队列:先进先出, 可以利用List左进右出,或者右进左出(Lis ...
- java多线程 生产者消费者模式
package de.bvb; /** * 生产者消费者模式 * 通过 wait() 和 notify() 通信方法实现 * */ public class Test1 { public static ...
- LabVIEW之生产者/消费者模式--队列操作 彭会锋
LabVIEW之生产者/消费者模式--队列操作 彭会锋 本文章主要是对学习LabVIEW之生产者/消费者模式的学习笔记,其中涉及到同步控制技术-队列.事件.状态机.生产者-消费者模式,这几种技术在在本 ...
- 转:Task任务调度实现生产者消费者模式 (个人理解后文)
纯属个人愚见.欢迎加入反驳(PiDou). 1.前文大致就是,利用Queue配置的一个TaskFactory任务调度器.实现生产者消费者模式的例子..首先我就试了 第一种 FIFO(先进先出)的配置. ...
- Lucene.net站内搜索—4、搜索引擎第一版技术储备(简单介绍Log4Net、生产者消费者模式)
目录 Lucene.net站内搜索—1.SEO优化 Lucene.net站内搜索—2.Lucene.Net简介和分词Lucene.net站内搜索—3.最简单搜索引擎代码Lucene.net站内搜索—4 ...
- MVC异常日志生产者消费者模式记录(异常过滤器)
生产者消费者模式 定义自己的异常过滤器并注册 namespace Eco.Web.App.Models { public class MyExceptionAttribute : HandleErro ...
- 转:Task任务调度实现生产者消费者模式
我们经常会遇到生产者消费者模式,比如前端各种UI操作事件触发后台逻辑等.在这种典型的应用场景中,我们可能会有4个业务处理逻辑(下文以P代表生产者,C代表消费者): 1. FIFO(先进先出) ...
随机推荐
- SQL中的ALL,ANY,SOME的用法
准备两个表: --T1(2,3)--T2(1,2,3,4) --ALL,ANY,SOME 的子查询-- >ALL 父查询中的结果集大于子查询中每一个结果集中的值,则为真SELECT * FROM ...
- ConcurrentDictionary与Dictionary 替换
本文导读:ASP.NET中ConcurrentDictionary是.Net4 增加的,相对于Dictionary的线程安全的集合, ConcurrentDictionary可实现一个线程安全的集合, ...
- [20181007]12cR2 Using SQL Patch 2.txt
[20181007]12cR2 Using SQL Patch 2.txt --//12cR2 已经把sql打补丁集成进入dbms_sqldiag,不是11g的 DBMS_SQLDIAG_INTERN ...
- mssql sqlserver避免sql脚本中出现除零错误的方法分享
摘自:http://www.maomao365.com/?p=6612 摘要:下文介绍sql server中,sql脚本避免出现除零错误的方法分享 在各种业务系统开发中,通常会遇到除零的错误,下文分享 ...
- C#发布和调试WebService
一.编写并发布WebService服务 1.新建空web应用程序
- 探索SQL Server元数据(三):索引元数据
背景 在第一篇中我介绍了如何访问元数据,元数据为什么在数据库里面,以及如何使用元数据.介绍了如何查出各种数据库对象的在数据库里面的名字.第二篇,我选择了触发器的主题,因为它是一个能提供很好例子的数据库 ...
- Linux 小知识翻译 - 「动态DNS」(DDNS)
这次聊聊「动态DNS」. DNS上周已经介绍过了,就是提供主机名和IP地址对应关系的结构.「动态DNS」是对主机名和IP地址的对应关系提供动态管理的结构. 以前的DNS没有考虑IP地址变化的情况.但是 ...
- js中图片上传,多次上传同一张不生效
在做图片上传的功能时, 使用删除功能删除了一张图片, 然后想重新上传原来删除的图片, 结果预览不显示, 也不能上传成功 解决办法, 在删除方法里置空input $("#id").f ...
- Tomcat结构
Tomcat结构 Server(服务器) 服务器代表整个Tomcat容器. Tomcat提供了服务器接口的默认实现(很少由用户定制). Service(服务) 服务是位于服务器内部的中间组件,将一个或 ...
- centos7下安装docker(16.1docker跨主机存储--Rex-Ray)
一.Rex-Ray以standalone进程的方式运行在docker主机上,安装方法很简单:在docker1和docker2上运行如下命令: curl -sSL https://dl.bintray. ...