使用 jms 队列。
ejb发件人:
@Resource(lookup = "jms/csPdvQueue")
private Queue csPdvQueue;
@Inject
private JMSContext jmsContext;
方法发送消息:
public void asynchWatched(Pdv pdv, boolean pending) {
jmsContext.createProducer().setDeliveryMode(DeliveryMode.NON_PERSISTENT);
jmsContext.createProducer().send(csPdvQueue, pdv);
}
ejb消费者:
@MessageDriven(mappedName = "jms/csPdvQueue")
public class PdvProcessorMdb implements MessageListener {
@Override
public void onMessage(Message message) {
... execute some businesslogic...
}
}
如果应用程序服务器(payara)在消息消费(onMessage)期间退出,则事务正确回滚。
当应用程序服务器再次启动时,即使我设置了 DeliveryMode.NON_PERSISTENT,消息也会重新传递。
我想避免重新发送消息。
有可能(以及如何)?