事务
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");