思诚科技 seecen LOGO
咨询热线:0791-87557233
  首页 |   Java EE  
关于思诚
关注官方微信

如何清除队列中的“死”消息?

来源:网络    更新时间:2014-12-16


什么是死消息?
当一个消息被返回或回收后,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 消息,并将他们放到当前或者远程队列中。

  • 上一篇文章:

  • 下一篇文章:
  •  

    0791-87557233

    重视每个来电 珍惜您的时间
    思诚者开发沙龙
    江西思诚科技有限公司  赣ICP备17006097号  CopyRight©2014 - 2018