1. ActiveMQ的生产者,消费者事务

  1. activemq的基本的消息发送操作:
package com.paic.mq;

import org.apache.activemq.ActiveMQConnectionFactory;
import javax.jms.*;

/**
 * 发送Activemq消息队列
 */
public class Producer {

    private static final String URL="tcp://127.0.0.1:61616";
    private static final String QUEUE_ANME="MY_FIRST QUEUE";

    public static void main(String[] args) throws JMSException {
        //1.创建服务链接工厂,使用默认的用户名和密码 admin/admin
        ActiveMQConnectionFactory factory = new ActiveMQConnectionFactory(URL);
        //2.创建连接对象
        Connection connection = factory.createConnection();
        connection.start();
        /**
         * false: 是否开启事务,如果是false,则消息会被直接提交至队列中
         * true: 表示开启事务,开启事务之后,需要显示提交事务/session.commit();
         * Session.AUTO_ACKNOWLEDGE: 签收
         */
        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
        //创建队列
        Queue queue = session.createQueue(QUEUE_ANME);
        MessageProducer producer = session.createProducer(queue);
        //发送具体的业务消息数据
        for (int i = 1; i <= 3; i++) {
            //消息体
            TextMessage textMessage = session.createTextMessage("this is sync "+i+" jj message");
            //将消息发送到MQ
            producer.send(textMessage);
        }
        //关闭资源
        producer.close();
        session.close();
        connection.close();
        System.out.println("******* message send over ************");
    }
}

消息的消费者:

package com.paic.mq;

import org.apache.activemq.ActiveMQConnectionFactory;
import javax.jms.*;

public class Consumer {

    private static final String URL = "tcp://127.0.0.1:61616";
    private static final String QUEUE_NAME = "MY_FIRST QUEUE";

    public static void main(String[] args) throws JMSException {
        //1.创建工厂对象
        ActiveMQConnectionFactory activeMQConnectionFactory = new ActiveMQConnectionFactory(URL);
        //2.创建链接对象
        Connection connection = activeMQConnectionFactory.createConnection();
        connection.start();
        //3.创建会话对象
        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
        //4.创建队列对象
        Queue queue = session.createQueue(QUEUE_NAME);
        //5.创建消费者
        MessageConsumer consumer = session.createConsumer(queue);
        while (true){
            TextMessage message = (TextMessage) consumer.receive();
            if (message != null) {
                String text = message.getText();
                System.out.println(text);
            } else {
                break;
            }
        }
        consumer.close();
        session.close();
        connection.close();
    }
}

  1. 生产者的事务介绍:
    true: 表示显示的开启事务,既然是显示的开启,则需要在会话中显示的提交事务/session.commit();
    如果没有commit();则消息不会入队列
    false: 表示不开启事务,消息会直接进入队列中.
    注意:当参数为true的时候,消息会先进入缓冲区,批量处理
  2. 既然有commit(),则必然有rollback();
    假设这一批次的消息中间有某条消息发生错误,则进行回滚操作.
		try{
            /**
             * 1. 消息正常的话,直接进行commit就行
             * 2. 中间某条消息异常,进行rollback();
             */
            session.commit();
        }catch (Exception e){
            session.rollback();
        }
  1. 消费者事务:
    同理,在消费侧,如果是开启事务true,则必须调用commit();
    否则消息中间件不认为该消息被消费了,就会出现消息被重复消息
    的情况.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值