ActiveMQ监听者接收信息

 1 import java.text.SimpleDateFormat;
 2 import java.util.Date;
 3 
 4 import javax.jms.Connection;
 5 import javax.jms.ConnectionFactory;
 6 import javax.jms.Destination;
 7 import javax.jms.JMSException;
 8 import javax.jms.Message;
 9 import javax.jms.MessageConsumer;
10 import javax.jms.MessageListener;
11 import javax.jms.Session;
12 import javax.jms.TextMessage;
13 
14 import org.apache.activemq.ActiveMQConnectionFactory;
15 
16 public class ActiveMQReceive {
17     //连接账号
18     private String userName = "";
19     //连接密码
20     private String password = "";
21     //连接地址
22     private String brokerURL = "tcp://192.168.18.161:61616";
23     //connection的工厂
24     private ConnectionFactory factory;
25     //连接对象
26     private Connection connection;
27     //一个操作会话
28     private Session session;
29     //目的地,其实就是连接到哪个队列,如果是点对点,那么它的实现是Queue,如果是订阅模式,那它的实现是Topic
30     private Destination destination;
31     //消费者,就是接收数据的对象
32     private MessageConsumer consumer;
33     
34     public static void main(String[] args) {
35         ActiveMQReceive receive = new ActiveMQReceive();
36         receive.start();
37     }
38     
39     public void start(){
40         try {
41             //根据用户名,密码,url创建一个连接工厂
42             factory = new ActiveMQConnectionFactory(userName, password, brokerURL);
43             //从工厂中获取一个连接
44             connection = factory.createConnection();
45             //连接启动
46             connection.start();
47             //创建一个session
48             //第一个参数:是否支持事务,如果为true,则会忽略第二个参数,被jms服务器设置为SESSION_TRANSACTED
49             //第二个参数为false时,paramB的值可为Session.AUTO_ACKNOWLEDGE,Session.CLIENT_ACKNOWLEDGE,DUPS_OK_ACKNOWLEDGE其中一个。
50             //Session.AUTO_ACKNOWLEDGE 为自动确认,客户端发送和接收消息不需要做额外的工作。哪怕是接收端发生异常,也会被当作正常发送成功。
51             //Session.CLIENT_ACKNOWLEDGE 为客户端确认。客户端接收到消息后,必须调用javax.jms.Message的acknowledge方法。jms服务器才会当作发送成功,并删除消息。
52             //DUPS_OK_ACKNOWLEDGE 允许副本的确认模式。一旦接收方应用程序的方法调用从处理消息处返回,会话对象就会确认消息的接收;而且允许重复确认。
53             session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
54             //创建一个到达的目的地,activemq不可能同时只能跑一个队列吧,这里就是连接了一个名为"Alarm"的队列,这个会话将会到这个队列,当然,如果这个队列不存在,将会被创建
55             destination = session.createTopic("Alarm");
56             //根据session,创建一个接收者对象
57             consumer = session.createConsumer(destination);
58             
59             
60             //实现一个消息的监听器
61             //实现这个监听器后,以后只要有消息,就会通过这个监听器接收到
62             consumer.setMessageListener(new MessageListener() {
63                 @Override
64                 public void onMessage(Message message) {
65                     try {
66                         //获取到接收的数据
67                         String text = ((TextMessage)message).getText();
68                         String time = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss SSS").format(new Date().getTime());
69                         System.out.println(time+":");
70                         System.out.println(text);
71                         System.out.println();
72                     } catch (JMSException e) {
73                         e.printStackTrace();
74                     }
75                 }
76             });
77             //关闭接收端,也不会终止程序哦
78 //            consumer.close();
79         } catch (JMSException e) {
80             e.printStackTrace();
81         }
82     }
83 }
原文地址:https://www.cnblogs.com/lhq1996/p/12786227.html