10.Curator队列
- ZK有1MB 的传输限制。实践中ZNode必须相对较小,而队列包含成千上万的消息,非常的大
- 如果有很多节点,ZK启动时相当的慢。而使用queue会导致好多ZNode。你需要显著增大 initLimit 和 syncLimit
- ZNode很大的时候很难清理。Netflix不得不创建了一个专门的程序做这事
- 当很大量的包含成千上万的子节点的ZNode时,ZK的性能变得不好
- ZK的数据库完全放在内存中。大量的Queue意味着会占用很多的内存空间
1.DistributedQueue
- QueueBuilder - 创建队列使用QueueBuilder,它也是其它队列的创建类
- QueueConsumer - 队列中的消息消费者接口
- QueueSerializer - 队列消息序列化和反序列化接口,提供了对队列中的对象的序列化和反序列化
- DistributedQueue - 队列实现类
public class DistributedQueueExample{private static final String PATH = "/example/queue";public static void main(String[] args) throws Exception{CuratorFramework clientA = CuratorFrameworkFactory.newClient("127.0.0.1:2181", new ExponentialBackoffRetry(1000, 3));clientA.start();CuratorFramework clientB = CuratorFrameworkFactory.newClient("127.0.0.1:2181", new ExponentialBackoffRetry(1000, 3));clientB.start();DistributedQueue<String> queueA = null;QueueBuilder<String> builderA = QueueBuilder.builder(clientA, createQueueConsumer("A"), createQueueSerializer(), PATH);queueA = builderA.buildQueue();queueA.start();DistributedQueue<String> queueB = null;QueueBuilder<String> builderB = QueueBuilder.builder(clientB, createQueueConsumer("B"), createQueueSerializer(), PATH);queueB = builderB.buildQueue();queueB.start();for (int i = 0; i < 100; i++){queueA.put(" test-A-" + i);Thread.sleep(10);queueB.put(" test-B-" + i);}Thread.sleep(1000 * 10);// 等待消息消费完成queueB.close();queueA.close();clientB.close();clientA.close();System.out.println("OK!");}/** 队列消息序列化实现类 */private static QueueSerializer<String> createQueueSerializer(){return new QueueSerializer<String>(){@Overridepublic byte[] serialize(String item){return item.getBytes();}@Overridepublic String deserialize(byte[] bytes){return new String(bytes);}};}/** 定义队列消费者 */private static QueueConsumer<String> createQueueConsumer(final String name){return new QueueConsumer<String>(){@Overridepublic void stateChanged(CuratorFramework client, ConnectionState newState){System.out.println("连接状态改变: " + newState.name());}@Overridepublic void consumeMessage(String message) throws Exception{System.out.println("消费消息(" + name + "): " + message);}};}}
消费消息(A): test-A-0消费消息(A): test-B-0......消费消息(B): test-A-51消费消息(B): test-B-51消费消息(B): test-A-52消费消息(B): test-B-52消费消息(B): test-A-53消费消息(B): test-B-54消费消息(B): test-A-55......消费消息(A): test-A-99消费消息(A): test-B-99OK!

2.DistributedIdQueue
- 通过下面方法创建:builder.buildIdQueue()
- 放入元素时:queue.put(aMessage, messageId);
- 移除元素时:int numberRemoved = queue.remove(messageId);
public class DistributedIdQueueExample{private static final String PATH = "/example/queue";public static void main(String[] args) throws Exception{CuratorFramework client = CuratorFrameworkFactory.newClient("127.0.0.1:2181", new ExponentialBackoffRetry(1000, 3));client.start();DistributedIdQueue<String> queue = null;QueueConsumer<String> consumer = createQueueConsumer("A");QueueBuilder<String> builder = QueueBuilder.builder(client, consumer, createQueueSerializer(), PATH);queue = builder.buildIdQueue();queue.start();for (int i = 0; i < 10; i++){queue.put(" test-" + i, "Id" + i);Thread.sleep((long) (50 * Math.random()));queue.remove("Id" + i);}Thread.sleep(1000 * 3);queue.close();client.close();System.out.println("OK!");}......}
消费消息(A): test-2消费消息(A): test-3消费消息(A): test-4消费消息(A): test-7OK!
3.DistributedPriorityQueue
public class DistributedPriorityQueueExample{private static final String PATH = "/example/queue";public static void main(String[] args) throws Exception{CuratorFramework client = CuratorFrameworkFactory.newClient("127.0.0.1:2181", new ExponentialBackoffRetry(1000, 3));client.start();DistributedPriorityQueue<String> queue = null;QueueConsumer<String> consumer = createQueueConsumer("A");QueueBuilder<String> builder = QueueBuilder.builder(client, consumer, createQueueSerializer(), PATH);queue = builder.buildPriorityQueue(0);queue.start();for (int i = 0; i < 5; i++){int priority = (int) (Math.random() * 100);System.out.println("test-" + i + " 优先级:" + priority);queue.put("test-" + i, priority);Thread.sleep((long) (50 * Math.random()));}Thread.sleep(1000 * 2);queue.close();client.close();}......}
test-0 优先级:34test-1 优先级:51test-2 优先级:63test-3 优先级:45test-4 优先级:36消费消息(A): test-0消费消息(A): test-4消费消息(A): test-3消费消息(A): test-1消费消息(A): test-2OK!
4.DistributedDelayQueue
public class DistributedDelayQueueExample{private static final String PATH = "/example/queue";public static void main(String[] args) throws Exception{CuratorFramework client = CuratorFrameworkFactory.newClient("127.0.0.1:2181", new ExponentialBackoffRetry(1000, 3));client.start();DistributedDelayQueue<String> queue = null;QueueConsumer<String> consumer = createQueueConsumer("A");QueueBuilder<String> builder = QueueBuilder.builder(client, consumer, createQueueSerializer(), PATH);queue = builder.buildDelayQueue();queue.start();for (int i = 0; i < 10; i++){queue.put("test-" + i, System.currentTimeMillis() + 3000);}System.out.println("put 完成!");Thread.sleep(1000 * 5);queue.close();client.close();System.out.println("OK!");}......}
put 完成!消费消息(A): test-0消费消息(A): test-3消费消息(A): test-1消费消息(A): test-2消费消息(A): test-6消费消息(A): test-4消费消息(A): test-5消费消息(A): test-7消费消息(A): test-8消费消息(A): test-9OK!
5.SimpleDistributedQueue
// 创建public SimpleDistributedQueue(CuratorFramework client, String path)// 增加元素public boolean offer(byte[] data) throws Exception// 删除元素public byte[] take() throws Exception// 另外还提供了其它方法public byte[] peek() throws Exceptionpublic byte[] poll(long timeout, TimeUnit unit) throws Exceptionpublic byte[] poll() throws Exceptionpublic byte[] remove() throws Exceptionpublic byte[] element() throws Exception
-------------------------------------------------------------------------------------------------------------------------------
10.Curator队列的更多相关文章
- 10 阻塞队列 & 生产者-消费者模式
原文:http://www.cnblogs.com/dolphin0520/p/3932906.html 在前面我们接触的队列都是非阻塞队列,比如PriorityQueue.LinkedList(Li ...
- java数据结构-10循环队列
一.概念: 循环队列就是将队列存储空间的最后一个位置绕到第一个位置,形成逻辑上的环状空间,供队列循环使用 二.代码实现: @SuppressWarnings("unchecked" ...
- JUC 并发编程--10, 阻塞队列之--LinkedBlockingDeque 工作窃取, 代码演示
直接上代码 class LinkedBlockingDequeDemo { // 循环是否结束的开关 private static volatile boolean flag1 = true; pri ...
- java多线程系列10 阻塞队列模拟
接下来的几篇博客会介绍下juc包下的相关数据结构 包含queue,list,map等 这篇文章主要模拟下阻塞队列. 下面是代码 import java.util.LinkedList; import ...
- Nodejs事件引擎libuv源码剖析之:高效队列(queue)的实现
声明:本文为原创博文,转载请注明出处. 在libuv中,有一个只使用简单的宏封装成的高效队列(queue),现在我们就来看一下它是怎么实现的. 首先,看一下queue中最基本的几个宏: typede ...
- javascript数据结构与算法---队列
javascript数据结构与算法---队列 队列是一种列表,不同的是队列只能在队尾插入元素,在队首删除元素.队列用于存储按顺序排列的数据,先进先出,这点和栈不一样(后入先出).在栈中,最后入栈的元素 ...
- Java数据结构之队列的实现以及队列的应用之----简单生产者消费者应用
Java数据结构之---Queue队列 队列(简称作队,Queue)也是一种特殊的线性表,队列的数据元素以及数据元素间的逻辑关系和线性表完全相同,其差别是线性表允许在任意位置插入和删除,而队列只允许在 ...
- java中使用队列:java.util.Queue (转)
Queue接口与List.Set同一级别,都是继承了Collection接口.LinkedList实现了Queue接 口.Queue接口窄化了对LinkedList的方法的访问权限(即在方法中的参数类 ...
- java 队列基础操作
http://www.cnblogs.com/fuck1/p/5996116.html 队列(简称作队,Queue)也是一种特殊的线性表,队列的数据元素以及数据元素间的逻辑关系和线性表完全相同,其差别 ...
随机推荐
- 关于Cocos2d-x的瓦片地图
1.cocos2d-x的瓦片地图是用Tiled地图编辑器做的,这个软件开源,免费,一般都是用它制作瓦片地图. 2.瓦片地图是由块层和对象组成的,块层的作用是显示和一些重叠的时候覆盖角色的作用,而对象是 ...
- e645. 处理键盘事件
You can get the key that was pressed either as a key character (which is a Unicode character) or as ...
- 标准的 C++ 由三个重要部分组成
标准的 C++ 由三个重要部分组成: 核心语言,提供了所有构件块,包括变量.数据类型和常量,等等.C++ 标准库,提供了大量的函数,用于操作文件.字符串等.标准模板库(STL),提供了大量的方法,用于 ...
- java---EL与ONGL的区别
EL表达式: >>单纯在jsp页面中出现,是在四个作用域中取值,page,request,session,application.>>如果在struts环境中,它除了有在上面的 ...
- C/C++,从未过时的编程语言之父
C/C++,持续火爆的编程语言之父 --訪传智播客C/C++学院院长传智·萧峰 编程语言作为实现互联网+基础必备工具,构建着互联网行业美轮美奂的大时代.作为编程语言之父--C语言,更是如鱼得水,在甘愿 ...
- react新手入门(序)
之前在软件园使用的是react,当时为了做个集光推送,自己去搭过react,这次项目中继续使用react,于是又重新操作了遍,恰巧公司买了本react的书籍,这本书写的非常好,看着并不觉得拗口,很容易 ...
- Oracle查询优化--排序
--普通排序 SELECT * FROM emp ORDER BY sal DESC; --使用列序排序 DESC; --组合排序 DESC; --translate函数,参数分别用A.B.C表示 S ...
- ms-SQL 递归调用
----递归函数-------------------------------------------------------------------------- create function d ...
- plsql developer中,清除登录历史
需求描述: 在使用plsql developer的时候,发现登录的时候,有太多的历史,想要把这些登录历史清除掉, 在此记录下. 操作过程: 1.登录plsql developer(或者在登录时取消也会 ...
- oracle中获取执行计划
1. 预估执行计划 - Explain PlanExplain plan以SQL语句作为输入,得到这条SQL语句的执行计划,并将执行计划输出存储到计划表中. 首先,在你要执行的SQL语句前加expla ...