您可以在不删除消息的情况下从 Service Broker Queues 中读取数据吗?

问题描述

我们有一种情况,当记录更新时,我们希望将一条消息放入队列以供应用程序读取,然后应用程序将读取该消息并对其进行处理(将其路由到 ESB 上的某处)。

提出的问题是“如果我们从队列中读取消息,然后应用程序在消息被转发之前失败了怎么办?”有没有办法获取消息,对其采取行动,然后确定它已被处理,然后将其从队列中删除

有没有更好的方法解决这个问题?到目前为止,他们创建的解决方包括完全删除 SB 并编写触发器以将数据放入一个表中,然后该表将被轮询、处理和删除

解决方法

通常,人们会在交易中读取 (RECEIVE) 消息,并在快乐路径上读取 (COMMIT) 或在出错后读取 ROLLBACK。这将确保消息不会过早从队列中删除。此外,您还需要考虑如何处理有害消息。