如何清除队列中的“死”消息?
什么是死消息?
当一个消息被返回或回收后,JMS 立即准备再次发送该消息,但是错误情况仍可能没有被消除,并且应用程序可能仍然不能处理该消息。这样的消息就被称为死消息(dead message),仍然驻留在消息队列中。
解决方案A
如果指定的存活时间值 (JMSExpiration )
小于或等于指定的发送时间值,则消息发送成功。否则,消息会悄然无声地终止。
消息终止
当一个消息被发送到队列中时,客户可以指定一个“存活时间”值。JMS 提供者将不发送已超出存活时间的消息。当超出其存活时间时,存储在队列中的消息将会被删除。
注意:根据 JMS规范,javax.jms.Message 中的 setJMSExpiration()
方法不会被用到应用程序,它被 JMS 自己留作内部使用。然而,应用程序可能通过应用程序服务器设置消息的终止时间。
示例:JMSMessage PutMsg =
new JMSMessage(); PutMsg.setJMSDeliveryMode(MQC.MQPER_NOT_PERSISTENT);
PutMsg.setJMSExpiration(18000);
解决方案B
我们可以用一个叫 QueueClearProcessor.java 的独立程序,由它使用 QueueBrowser API 来浏览队列中的旧消息,并每隔一段时间将其从队列中清除。可以通过消息创建时间来识别出旧消息。为了访问创建时间戳,JMS 在消息对象中提供了一个 API 方法: (getJMSTimestamp())
解决方案 C
MQSeries Message Browser 提供一个便利的图形化界面来查看和操作 MQ 队列中的消息。通过这个工具 MQSeries 管理员可以在任何消息队列管理器上显示消息内容,并可以对每个消息进行操作。
可能的用途
消息浏览器可以用于:
1、显示任何 MQ 消息的完整内容(包括使用十六进制显示特征的非文本消息);
2、显示消息描述符中的字段和一个消息中内嵌的任何 MQ
标题;也可以显示匹配数字值的命名为 MQ 的常量;
3、在消息中或在一个队列的所有消息中搜索特定的消息内容;
4、从队列中移出单个的消息,或将它们转移到另一个队列中;
5、将 MQ 消息保存到文件;
6、创建新的 MQ 消息,并将他们放到当前或者远程队列中。