注意:redis客户端执行是单线程的,不能将客户端放在外面,内部执行使用多线程的方式。

        // 创建生产端连接
final Jedis jedisProducter = new Jedis(R_HOST, R_PORT);
jedisProducter.auth(R_AUTO); Runnable th1= new Runnable() {
@Override
public void run() {
jedisProducter.lpush(COMMON_KEY_APPLE, "producter2: ");
}
};

以上写法就会出错。除非写在一起。

生产者:

/**
* Redis实现消息队列
* @author DennyZhao
* @date 2018/07/06
*/
public class RedisQueueProducter { private final static String R_HOST="127.0.0.1";
private final static String R_AUTO = "dennyzhao";
private final static int R_PORT = 6380;
private final static String COMMON_KEY_APPLE = "APPLE"; public static void main(String[] args) throws InterruptedException {
// 创建生产端连接
final Jedis jedisProducter = new Jedis(R_HOST, R_PORT);
jedisProducter.auth(R_AUTO); while(true) {
//消费
long lenth = jedisProducter.llen(COMMON_KEY_APPLE);
// 生产
if(lenth < 10) {
System.out.println("库存告急.....");
Random sc = new Random();
jedisProducter.lpush(COMMON_KEY_APPLE, "producter2: " + sc.nextInt(8));
}
Thread.sleep(1000);
}
}
}

消费者:

/**
* Redis实现消息队列
* @author DennyZhao
* @date 2018/07/06
*/
public class RedisQueueCustomer { private final static String R_HOST="127.0.0.1";
private final static String R_AUTO = "dennyzhao";
private final static int R_PORT = 6380;
private final static String COMMON_KEY_APPLE = "APPLE"; public static void main(String[] args) throws InterruptedException { // 创建消费者连接
Jedis jedisCustomer = new Jedis(R_HOST, R_PORT);
jedisCustomer.auth(R_AUTO); while(true) {
//消费
System.out.println(jedisCustomer.blpop(2, COMMON_KEY_APPLE)); Thread.sleep(1000);
}
}
}

Redis简单生产者消费者的更多相关文章

  1. 使用redis实现生产者消费者模式

    本次主要分享一下使用redis做缓存队列,实现生产者消费者模式. 首先先来看一下redis提供的列表操作接口.像ListRightPush就和符合队列先进先出的原则. 然后围绕这个列表已下单为例简要实 ...

  2. Java数据结构之队列的实现以及队列的应用之----简单生产者消费者应用

    Java数据结构之---Queue队列 队列(简称作队,Queue)也是一种特殊的线性表,队列的数据元素以及数据元素间的逻辑关系和线性表完全相同,其差别是线性表允许在任意位置插入和删除,而队列只允许在 ...

  3. Kafka 简单实验二(Python实现简单生产者消费者)

    Apache Kafka 是什么? Kafka 是一个开源的分布式流处理平台,其简化了不同数据系统的集成.流指的是一个数据管道,应用能够通过流不断地接收数据.Kafka 作为流处理系统主要有两个用处: ...

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

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

  5. .net学习之多线程、线程死锁、线程通信 生产者消费者模式、委托的简单使用、GDI(图形设计接口)常用的方法

    1.多线程简单使用(1)进程是不执行代码的,执行代码的是线程,一个进程默认有一个线程(2)线程默认情况下都是前台线程,要所有的前台线程退出以后程序才会退出,进程里默认的线程我们叫做主线程或者叫做UI线 ...

  6. python_way ,day11 线程,怎么写一个多线程?,队列,生产者消费者模型,线程锁,缓存(memcache,redis)

    python11 1.多线程原理 2.怎么写一个多线程? 3.队列 4.生产者消费者模型 5.线程锁 6.缓存 memcache redis 多线程原理 def f1(arg) print(arg) ...

  7. python JoinableQueue在生产者消费者项目中的简单应用

    class multiprocessing.JoinableQueue([maxsize]) JoinableQueue, a Queue subclass, is a queue which add ...

  8. Python-生成器实现简单的"生产者消费者"模型

    一.使用生成器实现简单的生产者消费者模型, 1.效果截屏 代码如下: import time def consumer(name): print('%s 开始买手机' %name) while Tru ...

  9. 生产者消费者模型及Golang简单实现

    简介:介绍生产者消费者模型,及go简单实现的demo. 一.生产者消费者模型 生产者消费者模型:某个模块(函数等〉负责产生数据,这些数据由另一个模块来负责处理(此处的模块是广义的,可以是类.函数.协程 ...

随机推荐

  1. PAT 乙级 1063 计算谱半径(20) C++版

    1063. 计算谱半径(20) 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 在数学中,矩阵的“谱半径”是指其特 ...

  2. Scrapy学习篇(四)之数据存储

    上一篇中,我们简单的实现了toscrapy网页信息的爬取,并存储到mongo,本篇文章信息看看数据的存储.这一篇主要是实现信息的存储,我们以将信息保存到文件和mongo数据库为例,学习数据的存储,依然 ...

  3. [UE4]创建游戏、加入游戏

    google搜: UE4 compile dedicated server,编译UE4专用服务器 UE4默认网络端口可以在引擎配置文件中修改: 一.创建文件.需要修改一下工程的配置文件DefaultE ...

  4. [UE4]在当前角色正前方2米处生成一个Actor

  5. 两种解决方法 PHP Warning: File upload error - unable to create a temporary file in Unknown

    原因:上传文件时,没有管理员权限的你不能读取临时文件夹; 解决方法(两种)找到临时文件夹并给当前访问用户所有权限; 方法一: 找到Apache默认的临时文件,步骤如下: 1.找到临时文件夹,一般在C: ...

  6. Java - 33 Java Applet基础

    Java Applet基础 applet是一种Java程序.它一般运行在支持Java的Web浏览器内.因为它有完整的Java API支持,所以applet是一个全功能的Java应用程序. 如下所示是独 ...

  7. for循环中进行联网请求数据、for循环中进行异步数据操作,数据排序错乱问题解决;

    for循环中进行联网请求数据,由于网络请求是异步的,第一个网络请求还没有回调,第二次第三次以及后续的网络请求又已经发出去了,有可能后续的网络请求会先回调:这时我们接收到的数据的排序就会错乱:怎么才能让 ...

  8. ES6入门声明

    let.var区别点 1.let只在命令所在的代码块中有效. 2.变量一定要先声明在使用,否则会报错,不存在Es5的变量提升(暂时性死区,不存在重复使用). 3.块级作用域中存在let命令,所声明的变 ...

  9. 文件替换(交互式)Replace

    在增量发版博文里,自动识别目标文件路径是采用了标记目录特征.当部署环境多变时,会多有不便.这个替换程序,在使用时需要手动输入目标目录.当需要进一步自动化时,可以与 fint 配合使用. 程序发布时,需 ...

  10. linux中测试py脚本使用debug模式

    python -mtrace --trace ping_host.py