activemq事务与ack消息确认

事务型消息发送端(生产端)

此处其它代码与普通式消息发送代码相似,只在以下几处有不同,首先在取得session时会声明事务开启“true”。
session = conn.createSession(true, Session.AUTO_ACKNOWLEDGE);  

然后在发送时会有一个动作:
producer.send(message);  
System.out.println("send......" + Thread.currentThread().getId());  
session.commit();  


相应的在catch(Exception)时需要
catch (Exception e) {  
                        e.printStackTrace();  
    try {  
        session.rollback();  
    } catch (Exception ex) {  
    }  
}   


事务型消息接收端(消费端)

在我们的接收端的createSession时也需要把它设为“事务开启”,此时请注意,生产和消费是在一个事务边界中的。
session = conn.createSession(true, Session.AUTO_ACKNOWLEDGE);  

然后在接收时会有一个动作:
try {  
    TextMessage tm = (TextMessage) message;  
    System.out.println("TranQConsumer receive message: " + tm.getText());  
    session.commit();  
  
} catch (Exception e) {  
    e.printStackTrace();  
    try {  
        session.rollback();  
    } catch (Exception ex) {  
    }  

}  

队列和订阅都是支持事务的。

在创建Session时,开发者不能指定除ACK_MODE列表之外的其他值.如果此session为事务类型,用户指定的ACK_MODE将被忽略,而强制使用"SESSION_TRANSACTED"类型;如果session非事务类型时,也将不能将 ACK_MODE设定为"SESSION_TRANSACTED",毕竟这是相悖的.   

ACK_MODE有四种

  • AUTO_ACKNOWLEDGE = 1    自动确认
  • CLIENT_ACKNOWLEDGE = 2    客户端手动确认   
  • DUPS_OK_ACKNOWLEDGE = 3    自动批量确认
  • SESSION_TRANSACTED = 0    事务提交并确认

欢迎加入我们的技术讨论群425783133

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值