Redis简单生产者消费者
注意: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简单生产者消费者的更多相关文章
- 使用redis实现生产者消费者模式
本次主要分享一下使用redis做缓存队列,实现生产者消费者模式. 首先先来看一下redis提供的列表操作接口.像ListRightPush就和符合队列先进先出的原则. 然后围绕这个列表已下单为例简要实 ...
- Java数据结构之队列的实现以及队列的应用之----简单生产者消费者应用
Java数据结构之---Queue队列 队列(简称作队,Queue)也是一种特殊的线性表,队列的数据元素以及数据元素间的逻辑关系和线性表完全相同,其差别是线性表允许在任意位置插入和删除,而队列只允许在 ...
- Kafka 简单实验二(Python实现简单生产者消费者)
Apache Kafka 是什么? Kafka 是一个开源的分布式流处理平台,其简化了不同数据系统的集成.流指的是一个数据管道,应用能够通过流不断地接收数据.Kafka 作为流处理系统主要有两个用处: ...
- Lucene.net站内搜索—4、搜索引擎第一版技术储备(简单介绍Log4Net、生产者消费者模式)
目录 Lucene.net站内搜索—1.SEO优化 Lucene.net站内搜索—2.Lucene.Net简介和分词Lucene.net站内搜索—3.最简单搜索引擎代码Lucene.net站内搜索—4 ...
- .net学习之多线程、线程死锁、线程通信 生产者消费者模式、委托的简单使用、GDI(图形设计接口)常用的方法
1.多线程简单使用(1)进程是不执行代码的,执行代码的是线程,一个进程默认有一个线程(2)线程默认情况下都是前台线程,要所有的前台线程退出以后程序才会退出,进程里默认的线程我们叫做主线程或者叫做UI线 ...
- python_way ,day11 线程,怎么写一个多线程?,队列,生产者消费者模型,线程锁,缓存(memcache,redis)
python11 1.多线程原理 2.怎么写一个多线程? 3.队列 4.生产者消费者模型 5.线程锁 6.缓存 memcache redis 多线程原理 def f1(arg) print(arg) ...
- python JoinableQueue在生产者消费者项目中的简单应用
class multiprocessing.JoinableQueue([maxsize]) JoinableQueue, a Queue subclass, is a queue which add ...
- Python-生成器实现简单的"生产者消费者"模型
一.使用生成器实现简单的生产者消费者模型, 1.效果截屏 代码如下: import time def consumer(name): print('%s 开始买手机' %name) while Tru ...
- 生产者消费者模型及Golang简单实现
简介:介绍生产者消费者模型,及go简单实现的demo. 一.生产者消费者模型 生产者消费者模型:某个模块(函数等〉负责产生数据,这些数据由另一个模块来负责处理(此处的模块是广义的,可以是类.函数.协程 ...
随机推荐
- bundle adjustment 玩具程序
结合 bundle adjustment原理(1) 和 Levenberg-Marquardt 的 MATLAB 代码 两篇博客的成果,调用MATLAB R2016a中 bundleAdjustmen ...
- 廖雪峰Java6IO编程-2input和output-1inputStream
1.InputStream 1.1InputStream是所有输入流的超类: int read() * 读取下一个字节,并返回字节(0-255) * 如果已读到末尾,返回-1 * read()方法是阻 ...
- Android 设置SeekBar不可拖动
public class MyProgressBar extends SeekBar { /** * 是否支持拖动进度 */ private boolean touch = true; public ...
- SCCM2012 R2实战系列之七:软件分发(exe)
在上一章节中,我们完成了SCCM 2012客户端代理软件的安装,现在就可以为客户端来部署应用程序了. SCCM2012增加了应用程序分发,同时保留了SCCM 2007里的包分发.应用程序分发可以直接对 ...
- Vue Admin 后台管理
https://segmentfault.com/a/1190000009188689
- but was actually of type 'com.sun.proxy.$Proxy101' 注入问题
最近在用springboot搭建项目框架时,遇到了如下错误,查询了一番,原来是没有引入spring框架的aop包导致: 问题: ERROR o.s.test.context.TestContextMa ...
- springboot获取application.yml中的配置信息
HelloController.java package com.springbootweb.demo.controller; import com.springbootweb.demo.entity ...
- 第9章 应用层(4)_超文本传输协议HTTP
5. 超文本传输协议HTTP 5.1 统一资源定位符URL (1)URL的一般形式:<协议>://<主机>:<端口>/<路径> ①协议后面必须写上“:/ ...
- 排序算法的python实现
几个排序算法 几个排序算法 冒泡排序 选择排序 插入排序 快速排序 quick sort 冒泡排序
- 添加删除mysql用户
create user 'hive_user'@'%' identified by '密码'; grant all privileges on hive.* to hive_user@'%'; cre ...