ActiveMQ(二) 其他

事务

Session可以被事务化, 也可以不被事务化, 通常, 可以通过向Connection上的适当创建方法传递一个布尔参数对此进行设置

Session createSession(Boolean transacted, int acknowledgeMode)

transacted为使用事务标识

结束事务有两种方法: 提交或者回滚。当一个事务提交, 消息被处理。如果事务中有一个步骤失败, 事务就回滚, 这个事务中的已经执行的动作将被撤销。

// 第三步: 通过Connection对象创建Session会话(上下文环境对象), 用于接收消息, 参数配置1为是否启用事务, 参数配置2为签收模式, 一般我们设置为自动签收
//使用事务的方式进行消息的发送
Session session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);

在发送消息最后也必须要使用session.commit()方法提交事务。

//使用事务提交
session.commit();

acknowledgeMode为签收模式

//使用CLIENT端签收的方式
Session session = connection.createSession(Boolean.TRUE, Session.CLIENT_ACKNOWLEDGE);

在接收方需要手工签收消息

//手工去签收消息. 另起一个线程(TCP)去通知我们的MQ服务确认签收
msg.acknowledge();

高级主题

p2p

p2p的过程理解起来更加简单, 它好比是两个人打电话, 这两个人是独享这一条通信链路的。一方发送消息, 另外一方接收

Destination destination=session.createQueue("queue1");

publish-subscribe

发布订阅模式有点类似日常生活中订阅报纸

Destination destination=session.createTopic("topic1");
发布了69 篇原创文章 · 获赞 8 · 访问量 9406

猜你喜欢

转载自blog.csdn.net/u011414629/article/details/102645614