JMS&MQ,从入门到精通(八)

本文我们来介绍一下TemporaryQueue和TemporaryQueue的使用,

    TemporaryQueue和TemporaryTopic,从字面上就可以看出它们是“临时”的目的地。可以通过Session来创建,例如:
 TemporaryQueue replyQueue = session.createTemporaryQueue();

 虽然它们是由Session来创建的,但是它们的生命周期确实整个Connection。如果在一个Connection上创建了两个Session,
 则一个Session创建的TemporaryQueue或TemporaryTopic也可以被另一个Session访问。那如果这两个Session是由不同的Connection创建,
 则一个Session创建的TemporaryQueue不可以被另一个Session访问。
 另外,它们的主要作用就是用来指定回复目的地, 即作为JMSReplyTo。
 在下面的例子中,先创建一个Connection,然后创建两个Session,其中一个Session创建了一个TemporaryQueue,
 另一个Session在这个TemporaryQueue上读取消息。

一个简单的实例

ActiveMQConnectionFactory factory = new ActiveMQConnectionFactory("vm://localhost");
Connection connection = factory.createConnection();
connection.start();

Queue queue = new ActiveMQQueue("testQueue2");
final Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
//使用session创建一个TemporaryQueue。
TemporaryQueue replyQueue = session.createTemporaryQueue();

//接收消息,并回复到指定的Queue中(即replyQueue)
MessageConsumer comsumer = session.createConsumer(queue);
comsumer.setMessageListener(new MessageListener() {
    public void onMessage(Message m) {
        try {
            System.out.println("Get Message: " + ((TextMessage) m).getText());
            MessageProducer producer = session.createProducer(m.getJMSReplyTo());
            producer.send(session.createTextMessage("ReplyMessage"));
        } catch (JMSException e) {
        }
    }
});

//使用同一个Connection创建另一个Session,来读取replyQueue上的消息。
Session session2 = connection.createSession(true, Session.AUTO_ACKNOWLEDGE);
MessageConsumer replyComsumer = session2.createConsumer(replyQueue);
replyComsumer.setMessageListener(new MessageListener() {
    public void onMessage(Message m) {
        try {
            System.out.println("Get reply: " + ((TextMessage) m).getText());
        } catch (JMSException e) {
        }
    }
});

MessageProducer producer = session.createProducer(queue);
TextMessage message = session.createTextMessage("SimpleMessage");
message.setJMSReplyTo(replyQueue);
producer.send(message);

我们来看一下运行结果

这里写图片描述

现在我们的连接都是用的虚拟连接,但是实际应用中肯定不是这么做的,实际开发中我们需要下载apache-activemq-5.14.5-bin.tar.gz 手动运行

apache-activemq-5.14.5//bin/activemq.jar start

然后

ActiveMQConnectionFactory factory = new ActiveMQConnectionFactory();
factory.setPassword("admin");
factory.setUserName("admin");
factory.setBrokerURL("tcp://localhost:61616");
Connection connection = factory.createConnection();
connection.start();

这里的密码是默认密码,需要启动activeMq,activeMq也有自己的UI管理页面,启动之后

http://127.0.0.1:8161/admin/,即可看到页面,,默认密码:admin/admin

这里写图片描述

到此为止关于activeMq对于JMS的实现,基本介绍完毕,后续章节介绍rabbitMq对于JMS的实现.以及rabbitMq集群
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一缕阳光直射你的心扉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值