上述就是MQ中有关Consumer的类图,下面来介绍一下每个类

1.MQAdmin:底层类,上篇博客已经提过,就不再此重提

2.MQConsumer:Consumer公共的接口,常用的方法如下

如果消费失败的话,消息将会返回到broker中,并且延迟一会消费的时间

void sendMessageBack(final MessageExt msg, final int delayLevel, final String brokerName)  throws RemotingException, MQBrokerException, InterruptedException, MQClientException;

3.MQPushConsumer:Consumer的一种,应用通常向Consumer对象注册一个Listener接口,一旦收到消息,Consumer对象立刻回调Listener接口方法

4.MQPullConsumer:Consumer的一种,应用通常主动调用Consumer的拉消息方法从Broker拉消息,主动权由应用控制

在上图中出现了两类的消费者分别是PushConsumer和PullConsumer,下面来看一下

PushConsumer:通过注册监听的方式来消费信息

  1. <span style="font-family:Comic Sans MS;font-size:18px;">/**
  2. * @FileName: Consumer.java
  3. * @Package:com.test
  4. * @Description: TODO
  5. * @author: LUCKY
  6. * @date:2015年12月28日 下午2:43:23
  7. * @version V1.0
  8. */
  9. package com.test;
  10. import java.util.List;
  11. import com.alibaba.rocketmq.client.consumer.DefaultMQPushConsumer;
  12. import com.alibaba.rocketmq.client.consumer.listener.ConsumeConcurrentlyContext;
  13. import com.alibaba.rocketmq.client.consumer.listener.ConsumeConcurrentlyStatus;
  14. import com.alibaba.rocketmq.client.consumer.listener.MessageListenerConcurrently;
  15. import com.alibaba.rocketmq.common.consumer.ConsumeFromWhere;
  16. import com.alibaba.rocketmq.common.message.Message;
  17. import com.alibaba.rocketmq.common.message.MessageExt;
  18. /**
  19. * @ClassName: Consumer
  20. * @Description: 模拟消费者
  21. * @author: LUCKY
  22. * @date:2015年12月28日 下午2:43:23
  23. */
  24. public class ConsumerTest {
  25. public static void main(String[] args) {
  26. DefaultMQPushConsumer consumer=new DefaultMQPushConsumer("broker-a");
  27. consumer.setNamesrvAddr("100.66.154.81:9876");
  28. try {
  29. // 订阅PushTopic下Tag为push的消息,都订阅消息
  30. consumer.subscribe("PushTopic", "push");
  31. // 程序第一次启动从消息队列头获取数据
  32. consumer.setConsumeFromWhere(ConsumeFromWhere.CONSUME_FROM_FIRST_OFFSET);
  33. //可以修改每次消费消息的数量,默认设置是每次消费一条
  34. // consumer.setConsumeMessageBatchMaxSize(10);
  35. //注册消费的监听
  36. consumer.registerMessageListener(new MessageListenerConcurrently() {
  37. //在此监听中消费信息,并返回消费的状态信息
  38. public ConsumeConcurrentlyStatus consumeMessage(
  39. List<MessageExt> msgs,
  40. ConsumeConcurrentlyContext context) {
  41. // msgs中只收集同一个topic,同一个tag,并且key相同的message
  42. // 会把不同的消息分别放置到不同的队列中
  43. for(Message msg:msgs){
  44. System.out.println(new String(msg.getBody()));
  45. }
  46. return ConsumeConcurrentlyStatus.CONSUME_SUCCESS;
  47. }
  48. });
  49. consumer.start();
  50. Thread.sleep(5000);
  51. //5秒后挂载消费端消费
  52. consumer.suspend();
  53. } catch (Exception e) {
  54. e.printStackTrace();
  55. }
  56. }
  57. }
  58. </span>

 PullConsumer:通过拉去的方式来消费消息

  1. <span style="font-family:Comic Sans MS;font-size:18px;">/**
  2. * @FileName: Consumer.java
  3. * @Package:com.test
  4. * @Description: TODO
  5. * @author: LUCKY
  6. * @date:2015年12月28日 下午2:43:23
  7. * @version V1.0
  8. */
  9. package com.test;
  10. import java.util.Set;
  11. import com.alibaba.rocketmq.client.consumer.DefaultMQPullConsumer;
  12. import com.alibaba.rocketmq.client.consumer.MessageQueueListener;
  13. import com.alibaba.rocketmq.common.message.MessageQueue;
  14. /**
  15. * @ClassName: Consumer
  16. * @Description: 模拟消费者
  17. * @author: LUCKY
  18. * @date:2015年12月28日 下午2:43:23
  19. */
  20. public class ConsumerPullTest {
  21. public static void main(String[] args) {
  22. DefaultMQPullConsumer consumer=new DefaultMQPullConsumer();
  23. consumer.setNamesrvAddr("100.66.154.81:9876");
  24. consumer.setConsumerGroup("broker");
  25. try {
  26. consumer.start();
  27. Set<MessageQueue> messageQueues=  consumer.fetchSubscribeMessageQueues("PushTopic");
  28. for(MessageQueue messageQueue:messageQueues){
  29. System.out.println(messageQueue.getTopic());
  30. }
  31. //消息队列的监听
  32. consumer.registerMessageQueueListener("", new MessageQueueListener() {
  33. @Override
  34. //消息队列有改变,就会触发
  35. public void messageQueueChanged(String topic, Set<MessageQueue> mqAll,
  36. Set<MessageQueue> mqDivided) {
  37. // TODO Auto-generated method stub
  38. }
  39. });
  40. } catch (Exception e) {
  41. e.printStackTrace();
  42. }
  43. }
  44. }
  45. </span>

一般在应用中都会采用push的方法来自动的消费信息

详解RocketMQ中的consumer的更多相关文章

  1. jQuery:详解jQuery中的事件(二)

    上一篇讲到jQuery中的事件,深入学习了加载DOM和事件绑定的相关知识,这篇主要深入讨论jQuery事件中的合成事件.事件冒泡和事件移除等内容. 接上篇jQuery:详解jQuery中的事件(一) ...

  2. 图文详解Unity3D中Material的Tiling和Offset是怎么回事

    图文详解Unity3D中Material的Tiling和Offset是怎么回事 Tiling和Offset概述 Tiling表示UV坐标的缩放倍数,Offset表示UV坐标的起始位置. 这样说当然是隔 ...

  3. 【转】详解C#中的反射

    原帖链接点这里:详解C#中的反射   反射(Reflection) 2008年01月02日 星期三 11:21 两个现实中的例子: 1.B超:大家体检的时候大概都做过B超吧,B超可以透过肚皮探测到你内 ...

  4. 详解Webwork中Action 调用的方法

    详解Webwork中Action 调用的方法 从三方面介绍webwork action调用相关知识: 1.Webwork 获取和包装 web 参数 2.这部分框架类关系 3.DefaultAction ...

  5. 【转】详解JavaScript中的this

    ref:http://blog.jobbole.com/39305/ 来源:foocoder 详解JavaScript中的this JavaScript中的this总是让人迷惑,应该是js众所周知的坑 ...

  6. 深入详解SQL中的Null

    深入详解SQL中的Null NULL 在计算机和编程世界中表示的是未知,不确定.虽然中文翻译为 “空”, 但此空(null)非彼空(empty). Null表示的是一种未知状态,未来状态,比如小明兜里 ...

  7. java 乱码详解_jsp中pageEncoding、charset=UTF -8"、request.setCharacterEncoding("UTF-8")

    http://blog.csdn.net/qinysong/article/details/1179480 java 乱码详解__jsp中pageEncoding.charset=UTF -8&quo ...

  8. 详解Objective-C中委托和协议

    Objective-C委托和协议本没有任何关系,协议如前所述,就是起到C++中纯虚类的作用,对于“委托”则和协议没有关系,只是我们经常利用协议还实现委托的机制,其实不用协议也完全可以实现委托. AD: ...

  9. 举例详解Python中的split()函数的使用方法

    这篇文章主要介绍了举例详解Python中的split()函数的使用方法,split()函数的使用是Python学习当中的基础知识,通常用于将字符串切片并转换为列表,需要的朋友可以参考下   函数:sp ...

随机推荐

  1. 用HashMap优化斐波那契数列 java算法

    斐波那契是第一项为0,第二项为1,以后每一项是前面两项的和的数列. 源码:Fibonacci.java public class Fibonacci{ private static int times ...

  2. 28、editText只输入英文字母和'-',用于授权码输入

    InputFilter filter = new InputFilter() { @Override public CharSequence filter(CharSequence source, i ...

  3. [译]__main__ 顶级脚本环境

    'main'是其中顶级代码执行的范围的名称.一个模块的__name__可以从标准输入,脚本,或从一个交互式命令行中等方式被设置成等于'main'. 一个模块可以发现它是否是通过检查自身在主运行范围__ ...

  4. hdu3667

    Transportation Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)To ...

  5. 搜索引擎快捷导航:一个简单的chrome插件(教程)

    一.如何通过练习来提高学习新框架的最好姿势是:基于现有的业务来学习.即从工作中学习,从实践中学.但是,如果一直只使用新的框架来重写旧的业务,成长也会趋近于0.第一次,使用新框架时收获可能颇丰:第二次, ...

  6. openstack是什么?能干什么?

    openstack是什么?能干什么?涉及的初衷是什么?由什么来组成?刚接触openstack,说openstack不是一个软件,而是由多个组件进行组合,这是一个更深层次的理解,当我们看到dashboa ...

  7. 刷题总结——运输计划(bzoj4326)

    题目: 题目背景 NOIP2015 提高组 Day2 T3 题目描述 公元2044年,人类进入了宇宙纪元. L国有 n 个星球,还有 n-1 条双向航道,每条航道建立在两个星球之间,这 n-1 条航道 ...

  8. bzoj 4007 树形dp

    题目大意 脸哥最近来到了一个神奇的王国,王国里的公民每个公民有两个下属或者没有下属,这种关系刚好组成一个 n 层的完全二叉树.公民 i 的下属是 2 * i 和 2 * i +1.最下层的公民即叶子节 ...

  9. poj 6243 Dogs and Cages

    Dogs and Cages Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others)To ...

  10. Python入门--17--pickle

    pickle模块,实际用途也很简单.单一,主要用于保存列表(list),元祖(Tuple),字典(dictionary) 当然,一定是大的列表.字典什么的,成千上万行的字典.列表,才能凸显出它的用武之 ...