publish/subscribe
  
  特点:A发送的消息可以被所有监听A的对象的接收,就好比学校的广播,所有的学生都可以收听校园广播信息。
  
  消息生产者:
  
  package com.zhiwei.advanced.mq.activemq.sp;
  
  import javax.jms.Connection;
  
  import javax.jms.ConnectionFactory;
  
  import javax.jms.Destination;
  
  import javax.jms.MessageProducer;
  
  import javax.jms.Session;
  
  import javax.jms.TextMessage;
  
  import org.apache.activemq.ActiveMQConnection;
  
  import org.apache.activemq.ActiveMQConnectionFactory;
  
  /**
  
  * 发布/订阅消息模型 测试顺序:先订阅才能收到消息
  
  */
  
  public class JMSProducer {
  
  private final static String user = ActiveMQConnection.DEFAULT_USER; // 默认用户名
  
  private final static String password = ActiveMQConnection.DEFAULT_PASSWORD; // 默认密码
  
  private final static String brokeURL = ActiveMQConnection.DEFAULT_BROKER_URL; // 链接地址
  
  public static void main(String[] args) throws Exception {
  
   // 连接工厂
  
  ConnectionFactory factory = new ActiveMQConnectionFactory(JMSProducer.user, JMSProducer.password,JMSProducer.brokeURL);
  
  // 创建连接
  
  Connection connection = factory.createConnection();
  
  // 启动连接
  
  connection.start();
  
  // 接受或发送消息的线程
  
  Session session = connection.createSession(true, Session.AUTO_ACKNOWLEDGE);
  
  Destination destination = session.createTopic("FirstTopic"); // 创建消息主题:Destination子类:Queue/Topic
  
  MessageProducer messageProducer = session.createProducer(destination); // 创建消息生产者
  
  // 发送文本消息
  
  for (int i = 0; i < 10; i++) {
  
  TextMessage message = session.createTextMessage("JMS Provider发送消息:" + i);
  
  System.out.println("JMS Provider发送消息:" + i);
  
  messageProducer.send(message);
  
  }
  
  // 启用事务时session需要提交
  
  session.commit();
  
  session.close();
  
  connection.close();
  
  }
  
  }
  
  消息消费者1:
  
  package com.zhiwei.advanced.mq.activemq.sp;
  
  import javax.jms.Connection;
  
  import javax.jms.ConnectionFactory;
  
  import javax.jms.Destination;
  
  import javax.jms.MessageConsumer;
  
  import javax.jms.Session;
  
  import org.apache.activemq.ActiveMQConnection;
  
  import org.apache.activemq.ActiveMQConnectionFactory;
  
  /**
  
  * 发布/订阅消息模型
  
  *
  
  * 特別注意:发布订阅消息模型必须先客户端监听,然后主题发送消息
  
  */
  
  public class JMSConsumer01{
  
  private final static String user = ActiveMQConnection.DEFAULT_USER; // 默认用户名
  
  private final static String password www.yigouyule2.cn/= ActiveMQConnection.DEFAULT_PASSWORD; // 默认密码
  
  private final static String brokeURL = ActiveMQConnection.DEFAULT_BROKER_URL; // 链接地址
  
  public static void main(String[] args) throws Exception {
  
  ConnectionFactory factory www.zhenghongyule.cn= new ActiveMQConnectionFactory(JMSConsumer01.user, JMSConsumer01.password,JMSConsumer01.brokeURL); // 链接工厂
  
  Connection connection = factory.createConnection(); // 连接
  
  connection.start(); // 启动连接
  
  Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);// 接受或发送消息的线程:消费不需事务
  
  Destination destination =www. jiahuayulpt.com session.createTopic("FirstTopic"); // 创建连接消息主题:Destination子类:Queue/Topic
  
  MessageConsumer messageConsumer = session.createConsumer(destination); // 创建消息生产者
  
  messageConsumer.setMessageListener(new JMSListener()); //注册消息监听 :阻塞监听
  
  }
  
  }
  
  消息消费者2:
  
  package com.zhiwei.advanced.mq.activemq.sp;
  
  import javax.jms.Connection;
  
  import javax.jms.ConnectionFactory;
  
  import javax.jms.www.zhongyiyuL.cn Destination;
  
  import javax.jms.MessageConsumer;
  
  import javax.jms.Session;
  
  import org.apache.www.myzx157.com activemq.ActiveMQConnection;
  
  import org.apache.www.mytxyl1.com activemq.ActiveMQConnectionFactory;
  
  /**
  
  * 发布/订阅消息模型
  
  */
  
  public class JMSConsumer02{
  
  private final static String user = ActiveMQConnection.DEFAULT_USER; // 默认用户名
  
  private final static String password = ActiveMQConnection.DEFAULT_PASSWORD; // 默认密码
  
  private final static String brokeURL = ActiveMQConnection.DEFAULT_BROKER_URL; // 链接地址
  
  public static void main(String[] args) throws Exception {
  
  ConnectionFactory factory = new ActiveMQConnectionFactory(JMSConsumer02.user, JMSConsumer02.password,JMSConsumer02.brokeURL); // 链接工厂
  
  Connection connection = factory.createConnection(); // 连接
  
  connection.start(); // 启动连接
  
  Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);// 接受或发送消息的线程:消费不需事务
  
  Destination destination = session.createTopic("FirstTopic"); // 创建连接消息主题:Destination子类:Queue/Topic
  
  MessageConsumer messageConsumer = session.createConsumer(destination); // 创建消息生产者
  
  messageConsumer.setMessageListener(new JMSListener()); //注册消息监听 :阻塞监听
  
  }
  
  }
  
  消息队列监听器:
  
  package com.zhiwei.advanced.mq.activemq.sp;
  
  import javax.jms.JMSException;
  
  import javax.jms.Message;
  
  import javax.jms.MessageListener;
  
  import javax.jms.TextMessage;
  
  public class JMSListener implements MessageListener{
  
  @Override
  
  public void onMessage(Message message) {
  
  if(message instanceof TextMessage){
  
  try {
  
  System.out.println(((TextMessage) message).getText());
  
  } catch (JMSException e) {
  
  e.printStackTrace();
  
  }
  
  }

【ActiveMQ】- 发布/订阅模式的更多相关文章

  1. ActiveMQ发布订阅模式

    ActiveMQ的另一种模式就SUB/HUB即发布订阅模式,是SUB/hub就是一拖N的USB分线器的意思.意思就是一个来源分到N个出口.还是上节的例子,当一个订单产生后,后台N个系统需要联动,但有一 ...

  2. ActiveMQ发布订阅模式(转)

    ActiveMQ的另一种模式就SUB/HUB即发布订阅模式,是SUB/hub就是一拖N的USB分线器的意思.意思就是一个来源分到N个出口.还是上节的例子,当一个订单产生后,后台N个系统需要联动,但有一 ...

  3. ActiveMQ发布订阅模式 转发 https://www.cnblogs.com/madyina/p/4127144.html

    ActiveMQ的另一种模式就SUB/HUB即发布订阅模式,是SUB/hub就是一拖N的USB分线器的意思.意思就是一个来源分到N个出口.还是上节的例子,当一个订单产生后,后台N个系统需要联动,但有一 ...

  4. ACtiveMQ中间件-发布订阅模式

    前言:ActiveMQ学习心得 1.MQ是什么 MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法.应用程序通过读写出入队列的消息(针对应用程序的数据)来通信, ...

  5. ActiveMQ (二)—发布订阅模式

    ActiveMQ的另一种模式就SUB/HUB即发布订阅模式,是SUB/hub就是一拖N的USB分线器的意思.意思就是一个来源分到N个出口.还是上节的例子,当一个订单产生后,后台N个系统需要联动,但有一 ...

  6. ActiveMQ发布-订阅消息模式(同点对点模式的区别)

    点对点与发布订阅最初是由JMS定义的.这两种模式主要区别或解决的问题就是发送到队列的消息能否重复消费(多订阅) 点对点: 消息生产者生产消息发送到queue中,然后消息消费者从queue中取出并且消费 ...

  7. SpringBoot2.0之整合ActiveMQ(发布订阅模式)

    发布订阅模式与前面的点对点模式很类似,简直一毛一样 注意:发布订阅模式 先启动消费者 公用pom: <project xmlns="http://maven.apache.org/PO ...

  8. ActiveMQ入门系列三:发布/订阅模式

    在上一篇<ActiveMQ入门系列二:入门代码实例(点对点模式)>中提到了ActiveMQ中的两种模式:点对点模式(PTP)和发布/订阅模式(Pub & Sub),详细介绍了点对点 ...

  9. ActiveMQ的p2p模式与发布订阅模式

    1.消息中间件:采用异步通讯防止,支持点对点以及发布订阅模式,可以解决高并发问题        传统调用接口,可能发生阻塞,重复提交,超时等等问题,可以利用消息中间件发送异步通讯请求          ...

  10. redis实现消息队列&发布/订阅模式使用

    在项目中用到了redis作为缓存,再学习了ActiveMq之后想着用redis实现简单的消息队列,下面做记录.   Redis的列表类型键可以用来实现队列,并且支持阻塞式读取,可以很容易的实现一个高性 ...

随机推荐

  1. Revit开发小技巧——撤销操作

    最近开发Revit命令需要限制某些操作,思路是监控用户操作,如果达到限制条件,将操作回退.思路有两种: 1.调用WindowsAPI,发送快捷命令Ctrl+Z. 2.通过Revit底层提供DLL找到回 ...

  2. XSS分类&危害&防御

    XSS(跨站脚本)漏洞是什么? 在网页中插入恶意的js脚本,由于网站没对其过滤,当用户浏览时,就会触发脚本,造成XSS攻击 XSS分类? 1.反射型 用户输入的注入代通过浏览器传入到服务器后,又被目标 ...

  3. Oracle数据库之分组查询及排序

    分组查询:使用 group by 来设置分组,把该列具有相同值的多条记录当成一组记录来处理,然后只会输出一条记录,得到的结果会默认使用升序的方式进行排列. 规则: (1)如果使用了分组函数,或者是 g ...

  4. Netty源码分析第5章(ByteBuf)---->第5节: directArena分配缓冲区概述

    Netty源码分析第五章: ByteBuf 第五节: directArena分配缓冲区概述 上一小节简单分析了PooledByteBufAllocator中, 线程局部缓存和arean的相关逻辑, 这 ...

  5. 基于KVM的H3C云计算平台CAS运维经验

  6. 安装keystone时创建用户失败

    系统:centos7.3 版本:openstack ocata 1.问题描述 安装keystone在创建用户时报错: The request you have made requires authen ...

  7. [朴孝敏][Road Trip]

    歌词来源:http://music.163.com/#/song?id=406907305 作曲 : Ryan S. Jhun/G'harah 'PK' Degeddingseze/Denzil Re ...

  8. ubuntu安装中文输入法必看

    ubuntu安装中文输入法必看以下两篇文章,按照顺序来做: http://www.2cto.com/os/201207/144189.html http://www.cnblogs.com/slide ...

  9. jQuery源码分析之整体框架

    之前只是知道jQuery怎么使用,但是我觉得有必要认真的阅读一下这个库,在分析jQuery源码之前,很有必要对整个jQuery有个整体的框架概念,才能方便后面对jQuery源码的分析和学习,以下是我总 ...

  10. 图层损坏 E/ArcGIS﹕ The map or layer has been destroyed or recycled. 资源未释放

    看到论坛上有个网友和我一样的问题: The map or layer has been destroyed or recyled t Hello, I have a problem when the ...