2,ActiveMQ-Queues点对点消息-Receive+Listener方式

本文介绍如何使用ActiveMQ实现点对点消息传递,包括生产者发送消息到队列及消费者采用Receive和Listener两种方式进行消息消费的过程。

本节主要实现ActiveMQ-Queues点对点消息生产者及消费者的Receive+Listener两种接收方式

一,实现步骤和预期

1,开启ActiveMQ服务-请参考 : ActiveMQ的下载,安装和启动
2,创建生产者,用于向指定队列发送测试数据
3,创建消费者-Receive方式,消费由生产者发送的队列的消息
4,创建消费者-Listener方式,消费由生产者发送的队列的消息
5,查看ActiveMQ后台,显示,生产者,消费者及消息的接收和处理状态


二,项目目录及依赖说明

这里写图片描述


三,生产者

以下代码实现了:连接ActiveMQ,创建队列,发送消息等一些列操作(见代码注释)

package com.brave.ActiveMQ.Producer;

import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.MessageProducer;
import javax.jms.Session;
import javax.jms.TextMessage;
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;

/**
 * 消息生产者 
 * @author Brave
 *
 */
public class Producer {

    private static final String USERNAME = ActiveMQConnection.DEFAULT_USER;
    private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD;
    private static final String BROKEURL = ActiveMQConnection.DEFAULT_BROKER_URL;

    public static void main(String[] args) {

        ConnectionFactory connectionFactory;    //连接工厂
        Connection connection = null;// 连接
        Session session; //会话
        Destination destination; //消息地址
        MessageProducer messageProducer; //消息生产者

        // 实例化连接工厂
        connectionFactory = new ActiveMQConnectionFactory(USERNAME, PASSWORD, BROKEURL);

        try {
            // 创建连接
            connection = connectionFactory.createConnection();
            // 连接开启
            connection.start();
            // 创建Session会话
            // 参数1:是否开启事务
            // 参数2:会话Session
            //  Session.AUTO_ACKNOWLEDGE - 自动确认 消费者从receive或监听成功返回时,自动确认客户端收到消息
            //  Session.CLIENT_ACKNOWLEDGE - 客户通过acknowledge方法确认消息(会话层确认),确认一个即确认所有
            //  Session.DUPS_OK_ACKNOWLEDGE - 重复确认
            session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
            // 创建消息队列
            destination = session.createQueue("TestQueue"); 
            // 创建消息生产者
            messageProducer = session.createProducer(destination);
            // 发送消息
            sendMessage(session, messageProducer);
            // 由于加入了Session,需要提交
            session.commit();
        } catch (Exception e) {
            e.printStackTrace();
            System.out.println("错误类名称 = " + e.getClass().getName());
            System.out.println("错误原因 = " + e.getMessage());
        }finally { //发送完毕后-关闭释放
            if(connection != null){
                try {
                    connection.close();
                    connection = null;
                } catch (JMSException e) {
                    e.printStackTrace();
                }
            }
        }
    }


    /**
     * 发送消息
     * @param session           会话
     * @param messageProducer   消息生产者对象
     * @throws JMSException 
     */
    private static void sendMessage(Session session, MessageProducer messageProducer) throws JMSException{
        for(int i = 0; i < 10; i++){
            TextMessage textMessage = session.createTextMessage("TestMessage:index = " + i);
            System.out.println("ActiveMQ-生产者-发送消息-index = " + i);
            messageProducer.send(textMessage);
        }
    }

}

运行生产者main方法 : 发10条消息,由于暂时没有消费者,消息将堆积在队列中

生产者发送消息Log:

生产者发送消息Log

生产者发送消息后台查询:

生产者发送消息后台查询

后台显示在TestQueue队列中有10条消息,并且未被消费者消费


四,消费者-Receive轮循方式

以下代码实现一个消费者:以轮训读取方式获取指定队列来自生产者发送的消息(具体流程见代码注释)

package com.brave.ActiveMQ.Consumer_Receive;

import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.MessageConsumer;
import javax.jms.Session;
import javax.jms.TextMessage;
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;

/**
 * 消息消费者
 *      方式一:Receive方式(不推荐)
 * 
 * @author Brave
 *
 */
public class Consumer_Receive {

    private static final String USERNAME = ActiveMQConnection.DEFAULT_USER;
    private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD;
    private static final String BROKEURL = ActiveMQConnection.DEFAULT_BROKER_URL;

    public static void main(String[] args) {

        ConnectionFactory connectionFactory;    // 连接工厂
        Connection connection = null;           // 连接
        Session session;                        // 会话
        Destination destination;                // 消息地址
        MessageConsumer messageConsumer;        // 消息消费者

        // 实例化连接工厂
        connectionFactory = new ActiveMQConnectionFactory(USERNAME, PASSWORD, BROKEURL);

        try {
            // 创建连接
            connection = connectionFactory.createConnection();
            // 连接开启
            connection.start();
            // 创建Session会话
            // 参数1:是否开启事务
            // 参数2:会话Session
            //  Session.AUTO_ACKNOWLEDGE - 自动确认 消费者从receive或监听成功返回时,自动确认客户端收到消息
            //  Session.CLIENT_ACKNOWLEDGE - 客户通过acknowledge方法确认消息(会话层确认),确认一个即确认所有
            //  Session.DUPS_OK_ACKNOWLEDGE - 重复确认
            session = connection.createSession(Boolean.FALSE, Session.AUTO_ACKNOWLEDGE);
            // 创建连接消息队列
            destination = session.createQueue("TestQueue"); 
            // 创建消息消费者
            messageConsumer = session.createConsumer(destination);

            // 接收数据-Receive方式-由于一直要轮训接收,不推荐
            while(true){
                TextMessage textMessage= (TextMessage)messageConsumer.receive(10000);//每10000毫秒接收一次消息
                if(textMessage != null){
                    System.out.println("消费者-Receive方式-收到消息: " + textMessage.getText());
                }
            }

        } catch (Exception e) {
            e.printStackTrace();
            System.out.println("错误类名称 = " + e.getClass().getName());
            System.out.println("错误原因 = " + e.getMessage());
        }finally { //关闭释放
            if(connection != null){
                try {
                    connection.close();
                    connection = null;
                } catch (JMSException e) {
                    e.printStackTrace();
                }
            }
        }

    }
}

消费者接收消息Log:

消费者接收消息Log

消费者接收消息后台查询:

消费者接收消息后台查询

后台显示,刚刚生产者发送的10调消息,已经被消费者消费了


四,消费者-Listening监听方式

以下代码实现一个消费者:以监听方式获取指定队列来自生产者发送的消息(具体流程见代码注释)

package com.brave.ActiveMQ.Consumer_Listener;

import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.MessageConsumer;
import javax.jms.Session;
import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory;

/**
 * 消息消费者
 *      方式二:Listener方式(推荐)
 * 
 * @author Brave
 *
 */
public class Consumer_Listener {

    private static final String USERNAME = ActiveMQConnection.DEFAULT_USER;
    private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD;
    private static final String BROKEURL = ActiveMQConnection.DEFAULT_BROKER_URL;

    public static void main(String[] args) {

        ConnectionFactory connectionFactory;    // 连接工厂
        Connection connection = null;           // 连接
        Session session;                        // 会话
        Destination destination;                // 消息地址
        MessageConsumer messageConsumer;        // 消息消费者
        // 实例化连接工厂
        connectionFactory = new ActiveMQConnectionFactory(USERNAME, PASSWORD, BROKEURL);

        try {
            // 创建连接
            connection = connectionFactory.createConnection();
            // 连接开启
            connection.start();
            // 创建Session会话
            // 参数1:是否开启事务
            // 参数2:会话Session
            //  Session.AUTO_ACKNOWLEDGE - 自动确认 消费者从receive或监听成功返回时,自动确认客户端收到消息
            //  Session.CLIENT_ACKNOWLEDGE - 客户通过acknowledge方法确认消息(会话层确认),确认一个即确认所有
            //  Session.DUPS_OK_ACKNOWLEDGE - 重复确认
            session = connection.createSession(Boolean.FALSE, Session.AUTO_ACKNOWLEDGE);
            // 创建连接消息队列
            destination = session.createQueue("TestQueue"); 
            // 创建消息消费者
            messageConsumer = session.createConsumer(destination);
            //Listener方式:注册消息监听器
            messageConsumer.setMessageListener(new MessageListener());

        } catch (Exception e) {
            e.printStackTrace();
            System.out.println("错误类名称 = " + e.getClass().getName());
            System.out.println("错误原因 = " + e.getMessage());
        }finally { //关闭释放
//          if(connection != null){
//              try {
//                  connection.close();
//                  connection = null;
//              } catch (JMSException e) {
//                  e.printStackTrace();
//              }
//          }
        }

    }
}
package com.brave.ActiveMQ.Consumer_Listener;

import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.TextMessage;

/**
 * 消息监听器
 * @author Brave
 *
 */
public class MessageListener implements javax.jms.MessageListener {

    @Override
    public void onMessage(Message message) {
        try {
            System.out.println("消费者-监听方式-收到消息: " + ((TextMessage)message).getText());
        } catch (JMSException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    }

}

我们再次使用生产者代码生产10条测试数据

再次生产10条数据

启动监听方式的消费者,并查看Log:

监听方式消费者Log

消费者接收消息后台查询:

消费者接收消息后台查询1

后台显示:新创建的10条数据已成功被消费了


五,代码下载:

优快云下载

GitHub下载

更新记录:

20170503:

添加项目结构和项目依赖说明配图
重构项目,更新代码段
更新优快云项目地址为重构项目
更新GitHub项目地址为重构项目
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

BraveWangDev

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值