Java實現ActiveMQ之隊列的生產者和消費者(一)

1、創建maven項目,導入pom.xml依賴包

<!--activemq所需依賴jar配置-->
<dependency>
    <groupId>org.apache.activemq</groupId>
    <artifactId>activemq-all</artifactId>
    <version>5.15.9</version>
</dependency>

2、JmsProduce.java 生產者

/**
 * 生產者
 */
public class JmsProduce {

    //工廠連接地址
    private static final String ACTIVEMQ_URL = "tcp://192.168.150.131:61616";

    //隊列名稱
    private static final String QUEUE_NAME = "queue01";

    public static void main(String[] args) throws JMSException {

        //1、創建連接工廠,按照給定的url,採用默認的用戶名和密碼
        ActiveMQConnectionFactory activeMQConnectionFactory = new ActiveMQConnectionFactory(ACTIVEMQ_URL);

        //2、通過連接工廠獲得連接connection並啓動訪問
        Connection connection = activeMQConnectionFactory.createConnection();
        connection.start();

        //3、創建會話  兩個參數:第一個(事務),第二個(簽收)
        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);

        //4、創建目的地(隊列還是主題),先創建隊列
        //Destination destination = session.createQueue(QUEUE_NAME); //父接口 目的地:(包括隊列和主題)
        Queue queue = session.createQueue(QUEUE_NAME);

        //5、創建消息的生產者
        MessageProducer messageProducer = session.createProducer(queue);

        //6、通過使用消息生產者生產10條消息發送到MQ隊列裏面
        for (int i = 1; i <=10 ; i++) {
            //7、創建消息
            TextMessage textMessage = session.createTextMessage("msg---" + i);//理解爲一個字符串
            //8、通過消息生產者(MessageProducer)發送給MQ
            messageProducer.send(textMessage);
        }

        //9、關閉資源
        messageProducer.close();
        session.close();
        connection.close();

        System.out.println("消息發送完成!");

    }
}

3、JmsConsumer.java 消費者 (同步阻塞方式)

/**
 * 消費者 (同步阻塞方式)
 */
public class JmsConsumer {

    //工廠連接地址
    private static final String ACTIVEMQ_URL = "tcp://192.168.150.131:61616";

    //隊列名稱
    private static final String QUEUE_NAME = "queue01";

    public static void main(String[] args) throws JMSException {

        //1、創建連接工廠,按照給定的url,採用默認的用戶名和密碼
        ActiveMQConnectionFactory activeMQConnectionFactory = new ActiveMQConnectionFactory(ACTIVEMQ_URL);

        //2、通過連接工廠獲得連接connection並啓動訪問
        Connection connection = activeMQConnectionFactory.createConnection();
        connection.start();

        //3、創建會話  兩個參數:第一個(事務),第二個(簽收)
        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);

        //4、創建目的地(隊列還是主題),先創建隊列
        //Destination destination = session.createQueue(QUEUE_NAME); //父接口 目的地:(包括隊列和主題)
        Queue queue = session.createQueue(QUEUE_NAME);

        //5、創建消費者
        MessageConsumer messageConsumer = session.createConsumer(queue);
        while (true){
            //消費方式: 死等receive()和 超時等receive(5000L)
            TextMessage textMessage = (TextMessage) messageConsumer.receive(5000L); //裝換類型,同一種格式
            if(null != textMessage){
                System.out.println("消費者接受到消息:"+textMessage.getText());
            }else {
                break;
            }
        }

        //6、倒着關閉資源
        messageConsumer.close();
        session.close();
        connection.close();
    }
}

4、JmsConsumerMonitor.java 消費者 異步非阻塞方式(監聽方式)

/**
 * 消費者 異步非阻塞方式(監聽方式)
 */
public class JmsConsumerMonitor {

    //工廠連接地址
    private static final String ACTIVEMQ_URL = "tcp://192.168.150.131:61616";

    //隊列名稱
    private static final String QUEUE_NAME = "queue01";

    public static void main(String[] args) throws JMSException, IOException {

        System.out.println("我是2號消費者......");

        //1、創建連接工廠,按照給定的url,採用默認的用戶名和密碼
        ActiveMQConnectionFactory activeMQConnectionFactory = new ActiveMQConnectionFactory(ACTIVEMQ_URL);

        //2、通過連接工廠獲得連接connection並啓動訪問
        Connection connection = activeMQConnectionFactory.createConnection();
        connection.start();

        //3、創建會話  兩個參數:第一個(事務),第二個(簽收)
        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);

        //4、創建目的地(隊列還是主題),先創建隊列
        //Destination destination = session.createQueue(QUEUE_NAME); //父接口 目的地:(包括隊列和主題)
        Queue queue = session.createQueue(QUEUE_NAME);

        //5、創建消費者
        MessageConsumer messageConsumer = session.createConsumer(queue);

        //6、通過監聽的方式
        messageConsumer.setMessageListener(new MessageListener(){
            @Override
            public void onMessage(Message message) {
                if(null != message && message instanceof TextMessage){
                    TextMessage textMessage = (TextMessage) message;
                    try {
                        System.out.println("消費者接受到消息:"+textMessage.getText());
                    } catch (JMSException e) {
                        e.printStackTrace();
                    }
                }
            }
        });
        System.in.read(); //保證控制檯不滅,一直輸出
        messageConsumer.close();
        session.close();
        connection.close();
    }
}

5、兩個消費者監聽着同一個隊列:效果圖

在這裏插入圖片描述
當生產者發送消息的時候,兩個消費者消費方式類似於輪訓的方式,一人消費一半
在這裏插入圖片描述
控制檯打印:
在這裏插入圖片描述
在這裏插入圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章