========================== 2017/3/31更新=======================
redisson实现了分布式和可扩展的java数据结构,支持的数据结构有:List, Set, Map, Queue, SortedSet, ConcureentMap, Lock, AtomicLong, CountDownLatch。并且是线程安全的,底层使用Netty 4实现网络通信。和jedis相比,功能比较简单,不支持排序,事务,管道,分区等redis特性,可以认为是jedis的补充,不能替换jedis。
redission.getQueue支持队列
==============================================================
在redis支持的数据结构中,有一个是集合list. 对List的操作常见的有lpush lrange等。在这种常见的操作时,我们是把集合当做典型意义上的‘集合’来使用的。往往容易被忽视的是List作为“队列”的使用情况。
反编译redis的jar包,会发现:
public String rpop(String key) { checkIsInMulti(); this.client.rpop(key); return this.client.getBulkReply(); } public String rpoplpush(String srckey, String dstkey) { checkIsInMulti(); this.client.rpoplpush(srckey, dstkey); return this.client.getBulkReply(); } public String lpop(String key) { checkIsInMulti(); this.client.lpop(key); return this.client.getBulkReply(); }
pop意为“弹”,是队列里的取出元素。rpop意为"right pop"意思就是从队列的右边取元素,lpop就是"left pop"当然就是从队列的左边取元素了。对应取元素,我们往队列里面Push元素同样有2个方向:
public Long lpush(String key, String[] strings) { checkIsInMulti(); this.client.lpush(key, strings); return this.client.getIntegerReply(); } public Long rpush(String key, String[] strings) { checkIsInMulti(); this.client.rpush(key, strings); return this.client.getIntegerReply(); }
好了,下面正式开始测试下redis中List数据结构作为队列的使用方法:
假设我需要往队列里面Push map,该怎么做呢? push String值的话比价简单,这里不再研究了……
往队列里push map的话,有以下2种方式:
第一种:
往队列里push一个map:
class PushThread implements Runnable { @Override public void run() { Jedis jedis = null; try{ jedis = JedisPoolUtils.getJedis(); for(int i=0; i<10; i++) { Map map = new HashMap(); map.put("test", "test" + i); map.put("ok", "ok" + i); jedis.lpush("test".getBytes(), ObjectUtils.objectToBytes(map));//Object对象转换成byte数组的方法,这里省略 } } catch(Exception e) { e.printStackTrace(); } finally{ JedisPoolUtils.returnRes(jedis); } } }
从队列里取出map:
class PopThread implements Runnable { @Override public void run() { Jedis jedis = null; try{ jedis = JedisPoolUtils.getJedis(); for(int i=0; i<10; i++) { byte[] key = jedis.rpop("test".getBytes()); System.out.println("弹出:" + ObjectUtils.bytesToObject(key));//byte数组转换为Object对象的方法,这里省略 } } catch(Exception e) { e.printStackTrace(); } finally{ JedisPoolUtils.returnRes(jedis); } }
依次启动Push线程和pop线程,可在pop线程端看到打印结果:
弹出:{ok=ok0, test=test0}
弹出:{ok=ok1, test=test1}
弹出:{ok=ok2, test=test2}
弹出:{ok=ok3, test=test3}
弹出:{ok=ok4, test=test4}
弹出:{ok=ok5, test=test5}
弹出:{ok=ok6, test=test6}
弹出:{ok=ok7, test=test7}
弹出:{ok=ok8, test=test8}
弹出:{ok=ok9, test=test9}
第二种方式:
因为第一种方式毕竟需要在byte数组和Object对象之间来回转换,效率上可能存在一定影响。所以我们加以改进。不妨只把map的key放在一个队列中,取队列元素时,只取key,然后根据key取map即可。
push:
class PushThread implements Runnable { @Override public void run() { Jedis jedis = null; try{ jedis = JedisPoolUtils.getJedis(); for(int i=0; i<10; i++) { Map map = new HashMap(); map.put("test", "test" + i); map.put("ok", "ok" + i); String key = "map" + i; jedis.lpush("test", key);//把所有map的key放入一个队列test中 jedis.hmset(key, map); } } catch(Exception e) { e.printStackTrace(); } finally{ JedisPoolUtils.returnRes(jedis); } }
pop元素:
class PopThread implements Runnable { @Override public void run() { Jedis jedis = null; try{ jedis = JedisPoolUtils.getJedis(); for(int i=0; i<10; i++) { String key = jedis.rpop("test"); System.out.println("弹出:" + jedis.hgetAll(key)); } } catch(Exception e) { e.printStackTrace(); } finally{ JedisPoolUtils.returnRes(jedis); } } }
依次启动Push线程和pop线程,可在pop线程端看到打印结果:
弹出:{test=test0, ok=ok0}
弹出:{test=test1, ok=ok1}
弹出:{test=test2, ok=ok2}
弹出:{test=test3, ok=ok3}
弹出:{test=test4, ok=ok4}
弹出:{test=test5, ok=ok5}
弹出:{test=test6, ok=ok6}
弹出:{test=test7, ok=ok7}
弹出:{test=test8, ok=ok8}
弹出:{test=test9, ok=ok9}
两种方式效果一样,只不过第二种效率上更好一些。
注:当你依次从队列里取出元素后,队列在redis中就不存在了,所以当你pop完元素,再尝试pop的话,会报异常:
redis.clients.jedis.exceptions.JedisDataException: value sent to redis cannot be null
同时,redis中这个队列也不复存在了!
利用redis作为队列的性质我们可以用它来达到类似ZMQ的作用。。
相关推荐
tornado-6.4.1-cp38-abi3-musllinux_1_2_i686.whl
tornado-6.1-cp36-cp36m-manylinux2014_aarch64.whl
基于java的ssm停车位短租系统程序答辩PPT.pptx
tornado-6.4b1-cp38-abi3-musllinux_1_1_x86_64.whl
基于java的招生管理系统答辩PPT.pptx
本压缩包资源说明,你现在往下拉可以看到压缩包内容目录 我是批量上传的基于SpringBoot+Vue的项目,所以描述都一样;有源码有数据库脚本,系统都是测试过可运行的,看文件名即可区分项目~ |Java|SpringBoot|Vue|前后端分离| 开发语言:Java 框架:SpringBoot,Vue JDK版本:JDK1.8 数据库:MySQL 5.7+(推荐5.7,8.0也可以) 数据库工具:Navicat 开发软件: idea/eclipse(推荐idea) Maven包:Maven3.3.9+ 系统环境:Windows/Mac
基于java的农机电招平台答辩PPT.pptx
jdk23 甲骨文官方安装包
基于java的机场网上订票系统答辩PPT.pptx
项目经过测试均可完美运行! 环境说明: 开发语言:java jdk:jdk1.8 数据库:mysql 5.7+ 数据库工具:Navicat11+ 管理工具:maven 开发工具:idea/eclipse
基于java的网上书店销售管理系统答辩PPT.pptx
tornado-6.3.3-cp38-abi3-win32.whl
【作品名称】:基于 Jsp+Sqlserver 实现的超市信息管理系统 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【项目介绍】: 系统功能: (1)系统分两种身份:管理员和员工,选择不同的身份进入不同的功能操作界面! (2)商品信息管理:管理员可以添加和维护商品信息,员工只能对商品信息进行查询 (3)员工信息管理:管理员登陆系统后可以可以添加和维护超市员工(收银员)的信息 (4)商品进货管理:管理员登陆系统后可以添加商品进货信息,可以对商品进货信息进行查询和统计,添加商品进进货退货信息,对商品进货退货信息进行查询和统计 (5)商品销售管理:员工(收银员)登陆系统后可以对商品进行销售,可以按时间查询自己的销售业绩;管理员登陆系统后可以按照时间等条件对销售信息进行查询,可以根据小票号登记顾客退货信息,查询顾客退货信息,可以查看员 【资源声明】:本资源作为“参考资料”而不是“定制需求”,代码只能作为参考,不能完全复制照搬。需要有一定的基础看懂代码,自行调试代码并解决报错,能自行添加功能修改代码。
tornado-6.3.2-cp38-abi3-musllinux_1_1_i686.whl
基于java的热带水果商城答辩PPT.pptx
java awt、Swing实现中国象棋可联机版本采用面向对象思想 采用面向对象的思路,实现中国象棋可联机版本,适合初学者,以及对面向对象有更深层次理解的开发者或者同学。 使用原生的java awt、Swing进行窗口式开发 将素材文件夹放在D:\Game路径下 两个工程直接导入Eclipse,即可运行, ps:一个工程运行两次也可以,需要注意端口号,代码默认如果连接的端口号是3003,则监听3004端口,相反同理。联机前需要确保两台计算机同时处于局域网或外网
web前端设计与开发(详细整理)(包含html讲解,css讲解,移动web讲解),合适学习前端的人员进行基础学习,一秒变高手
分析所需的数据和代码都在这里
Listening Exercise 3 Part 2.mp3
链表 删除链表中的重复元素,链表基础