• 04_ActiveMQ事务与三种签收方式


    【ActiveMQ添加事务】

    添加事务主要注意两点:

    1.修改Session配置,启用事务

    /**
     * 3.通过Connection对象创建Session会话(上下文环境对象),用于接收消息。
     *   参数1:是否启用事务 
     *   参数2:签收模式,一般设置为自动签收
     */
    Session session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);

    2.代码最后提交事务(必须要提交事务,不然在MQ上无法得到发送的消息)

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

    [ session设置启用事务,但不加session.commit(),执行代码之后,这里不会改变 ]

    [ 加了session.commit(),执行代码之后,MQ上就会有对应的消息 ]

    【三种签收方式】

    [ Session.AUTO_ACKNOWLEDGE ]

    当客户端从receiver或onMessage成功返回时,Session自动签收客户端的这条消息的收条。

    [ Session.CLIENT_ACKNOWLEDGE ]

    客户端通过调用消息(Message)的acknowledge方法签收消息。在这种情况下,签收发生在Session层面:签收一个已经消费的消息会自动地签收这个Session所有已消费的收条。

    [ Session.DUPS_OK_ACKNOWLEDGE ]

    Session不必确保对传送消息的签收,这个模式可能会引起消息的重复,但是降低了Session的开销,所以只有客户端能容忍重复的消息,才可使用。

    【  Session.CLIENT_ACKNOWLEDGE 签收方式

    [ 修改Send.java ]

    /**
     * 3.通过Connection对象创建Session会话(上下文环境对象),用于接收消息。
     *   参数1:是否启用事务 启用事务
     *   参数2:签收模式,修改为 客户端确认签收
     */
    Session session = connection.createSession(Boolean.TRUE, Session.CLIENT_ACKNOWLEDGE);

    [ 修改 Receiver.java ]

    消费者的session与生产者的session签收模式保持一致,注意,生产者启用事务了,但是消费者这里事务不要启用,不然会一直消费

    /**
     * 3.通过Connection对象创建Session会话(上下文环境对象),用于接收消息。
     *   参数1:是否启用事务 消费者不启用事务
     *   参数2:签收模式,修改为 客户端确认签收
     */
    Session session = connection.createSession(Boolean.FALSE, Session.CLIENT_ACKNOWLEDGE);
    消费者获取消息时添加一行:msg.acknowledge();
    /**
     * 7.最后,使用JMS规范的TextMessage形式创建数据(通过Session对象),
     *   发送端使用MessageProducer的Send方法发送数据。
     *   接受端使用receive方法接收数据。
     */
    while(true){
        TextMessage msg = (TextMessage)messageConsumer.receive();
        //消费者手工去签收消息,另起一个线程(TCP)去通知MQ服务确认消息签收
        msg.acknowledge();
        if(msg==null) 
            break;
        System.out.println("【消费者接收】"+msg.getText());
    }
  • 相关阅读:
    Linux 常用命令
    silky微服务简介
    okhttp中的Builder模式
    Assert in C#&Java
    Abstract类中使用@Autowire
    @Scope("prototype") bean scope not creating new bean
    【转】centos系统查看cpu内存等情况
    hdu 7013 String Mod 题解
    牛客 11259 H Scholomance Academy 题解
    bzoj 2151 种树 题解
  • 原文地址:https://www.cnblogs.com/HigginCui/p/8465760.html
Copyright © 2020-2023  润新知