深入掌握JMS(五):实战Topic
来源:互联网 发布:淘宝自定义属性 编辑:程序博客网 时间:2024/05/18 01:38
与Queue不同的是,Topic实现的是发布/订阅模型,在下面的例子中,启动2个消费者共同监听一个Topic,然后循环给这个Topic中发送多个消息。
javax.jms.Connection; import javax.jms.JMSException; import javax.jms.Message; import javax.jms.MessageConsumer; import javax.jms.MessageListener; import javax.jms.MessageProducer; import javax.jms.Session; import javax.jms.TextMessage; import javax.jms.Topic; import org.apache.activemq.ActiveMQConnectionFactory; import org.apache.activemq.command.ActiveMQTopic; public class TopicTest { public static void main(String[] args) throws Exception { ActiveMQConnectionFactory factory = new ActiveMQConnectionFactory("vm://localhost"); Connection connection = factory.createConnection(); connection.start(); //创建一个Topic Topic topic= new ActiveMQTopic("testTopic"); Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE); //注册消费者1 MessageConsumer comsumer1 = session.createConsumer(topic); comsumer1.setMessageListener(new MessageListener(){ public void onMessage(Message m) { try { System.out.println("Consumer1 get " + ((TextMessage)m).getText()); } catch (JMSException e) { e.printStackTrace(); } } }); //注册消费者2 MessageConsumer comsumer2 = session.createConsumer(topic); comsumer2.setMessageListener(new MessageListener(){ public void onMessage(Message m) { try { System.out.println("Consumer2 get " + ((TextMessage)m).getText()); } catch (JMSException e) { e.printStackTrace(); } } }); //创建一个生产者,然后发送多个消息。 MessageProducer producer = session.createProducer(topic); for(int i=0; i<10; i++){ producer.send(session.createTextMessage("Message:" + i)); } } }运行后得到下面的输出结果:
Consumer1 get Message:0 Consumer2 get Message:0 Consumer1 get Message:1 Consumer2 get Message:1 Consumer1 get Message:2 Consumer2 get Message:2 Consumer1 get Message:3 Consumer2 get Message:3 Consumer1 get Message:4 Consumer2 get Message:4 Consumer1 get Message:5 Consumer2 get Message:5 Consumer1 get Message:6 Consumer2 get Message:6 Consumer1 get Message:7 Consumer2 get Message:7 Consumer1 get Message:8 Consumer2 get Message:8 Consumer1 get Message:9 Consumer2 get Message:9说明每一个消息都会被所有的消费者消费。
0 0
- 深入掌握JMS(五):实战Topic
- 深入掌握JMS(五):实战Topic
- 深入掌握JMS(五):实战Topic
- 深入掌握JMS(五):实战Topic
- 深入掌握JMS(五):实战Topic
- 深入掌握JMS(五):实战Topic
- 深入掌握JMS(五):实战Topic
- 深入掌握JMS(五):实战Topic
- 深入掌握JMS(五):实战Topic
- 深入掌握JMS(五):实战Topic
- 深入掌握JMS(五):实战Topic
- 深入掌握JMS(五):实战Topic
- 深入掌握JMS(五):实战Topic
- 深入掌握JMS(五):实战Topic
- 深入掌握JMS(四):实战Queue
- 深入掌握JMS(四):实战Queue
- 深入掌握JMS(四):实战Queue
- 深入掌握JMS(四):实战Queue
- USACO 1.3-Wormholes
- android学习日志—AsyncTask源码分析
- ES6学习笔记
- ThreadLocal 使用
- 3
- 深入掌握JMS(五):实战Topic
- 【我的总结】HashMap和HashTable的区别
- 线段树的创建
- Linux 下fastdfs 安装 部署 测试
- 一道JAVA面试,线程安全和静态内部类
- Fragment 与 ViewPager
- 范范(8)
- 腾讯2016实习招聘(西安)部分在线笔试题
- 【codechef】交换字符串S的两个位置上的字符,求有多少对AB不相似