关闭Connection时,ActiveMQ NMS临时队列不会被破坏

时间:2013-08-28 11:36:46

标签: c# activemq nms

我在Active MQ文档中读到,当用于创建它们的连接关闭时,代理会删除临时队列。

我正在使用Apache NMS v1.5.0和Active MQ 5.1.3,即使连接超出范围,临时队列也始终保持不变。

我有一个客户端/服务器场景,客户端创建一个临时队列并创建一条消息,在消息的ReplyTo属性中指定临时队列。 然后,服务器组件读取消息并开始向回复队列发送消息。

不幸的是,当客户端关闭它的连接时,它创建的临时队列不会被删除。

以下代码段应说明我的意思。

我创建了一个连接,并使用该连接创建一个临时队列。 我关闭连接并创建第二个连接。 我不能使用会话在临时队列上生成和使用消息 由第二个连接创建,但我可以。

有人可以告诉我,我在这里做错了吗?如何让Active MQ删除临时队列。

任何帮助都非常感激。

[Test]
public void TempQueueTest()
{
    var cf = new ConnectionFactory("tcp://activemq-broker:61616");


    using (var connection = cf.CreateConnection())
    {
        connection.Start();

        using (var session = connection.CreateSession())
        {
            var normalQueue = session.GetQueue("normalQueue");

            ITemporaryQueue tempQueue = session.CreateTemporaryQueue();

            using (var producer = session.CreateProducer(normalQueue))
            {

                // create a messasge and put on a normal queue
                //specify the temp queue as the reply to queue

                var mesage = new ActiveMQTextMessage("hello");
                mesage.ReplyTo = tempQueue as ActiveMQDestination;
                producer.Send(mesage);
            }
        }
        connection.Stop();
    }


    // ok, connection has been disposed, so the temp queue should be destroyed

    // create a new connection
    using (var connection = cf.CreateConnection())
    {
        connection.Start();

        using (var session = connection.CreateSession())
        {
            var normalQueue = session.GetQueue("normalQueue");

            using (var consumer = session.CreateConsumer(normalQueue))
            {
                var message = consumer.Receive() as ActiveMQTextMessage;

                // replyToDest is the temp queue created with the previous connection
                var replyToDest = message.ReplyTo;


                using (var producer = session.CreateProducer(replyToDest))
                {
                    // i shouldn't be able to send a message to this temp queue
                    producer.Send(new ActiveMQTextMessage("this shouldn't work"));
                }

                using (var tempConsumer = session.CreateConsumer(replyToDest))
                {
                    // is shouldn't be able to receive messages on the temp queue as it should be destroyed
                    var message1 = tempConsumer.Receive() as ActiveMQTextMessage;
                }
            }

        }
        connection.Stop();
    }

}

1 个答案:

答案 0 :(得分:2)

鉴于您使用的古老版本,我不知道有什么方法可以解决这里发生的事情。代码看起来是正确的,但是在NMS库的v1.5.0版本和当前的1.6.0之间存在大量修复,其中许多修复了Temp Destinations的问题。我建议您尝试继续使用更高版本以查看问题是否消失。

现在您可能必须使用JMX来访问代理并删除旧的临时目标。