ActiveMQ Hello World

一)ActiveMQ必需的Jar

为了使ActiveMQ易于使用,默认的activemq-all.jar随附了所有必需的库。

<dependency>
    <groupId>org.apache.activemq</groupId>
    <artifactId>activemq-all</artifactId>
    <version>5.16.0</version>
</dependency>

或可显示指定ActiveMQ的Jar:

  • activemq-broker.jar
  • activemq-client.jar
  • activemq-kahadb-store.jar
  • activemq-spring.jar
  • hawtbuf-1.11.jar
  • slf4j-api.jar
  • slf4j-log4j12.jar
  • log4j-1.2.17.jar

 

二)ActiveMQ Queues点对点模式

含义:点对点,即一个生产者对应一个消费者。生产者生产一条数据,只能被一个消费者消费。

第一步:创建一个消息生产者

package com.oysept.queues;

import org.apache.activemq.ActiveMQConnectionFactory;

import javax.jms.Connection;
import javax.jms.DeliveryMode;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.MessageProducer;
import javax.jms.Session;
import javax.jms.TextMessage;

public class HelloWorldProducer {
    /**
     * 生产者,生产消息
     */
    public void producer() {
        try {
            // 创建一个ActiveMQ工厂
            ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory("amdin", "admin", "tcp://localhost:61616");

            // 创建连接
            Connection connection = connectionFactory.createConnection();
            connection.start();

            // 创建一个session
            /*
            JMS规范的ack消息确认机制有一下四种,定于在session对象中:
            AUTO_ACKNOWLEDGE = 1 :自动确认
            CLIENT_ACKNOWLEDGE = 2:客户端手动确认
            DUPS_OK_ACKNOWLEDGE = 3: 自动批量确认
            SESSION_TRANSACTED = 0:事务提交并确认
             */
            Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);

            // 创建目标(主题或队列)
            Destination destination = session.createQueue("test.ouyangjun");

            // 从会话到主题或队列创建MessageProducer
            MessageProducer messageProducer = session.createProducer(destination);
            messageProducer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);

            // 创建文本消息
            String msg = "HelloWorldProducer Text Received: HelloWorld!";
            TextMessage message = session.createTextMessage(msg);

            // 告诉制片人发送信息
            messageProducer.send(message);

            // 关闭
            messageProducer.close();
            session.close();
            connection.close();
        } catch (JMSException e) {
            e.printStackTrace();
        }
    }
}

 

第二步:创建一个消息消费者

package com.oysept.queues;

import org.apache.activemq.ActiveMQConnectionFactory;

import javax.jms.Connection;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.Session;
import javax.jms.TextMessage;

public class HelloWorldConsumer {
    /**
     * 消费者,消费消息
     */
    public void consumer() {
        try {
            // 创建一个ActiveMQ工厂
            ActiveMQConnectionFactory connectionFactory = new ActiveMQConnectionFactory("amdin", "admin", "tcp://localhost:61616");

            // 创建连接
            Connection connection = connectionFactory.createConnection();
            connection.start();

            // 创建一个session
            /*
            JMS规范的ack消息确认机制有一下四种,定于在session对象中:
            AUTO_ACKNOWLEDGE = 1 :自动确认
            CLIENT_ACKNOWLEDGE = 2:客户端手动确认
            DUPS_OK_ACKNOWLEDGE = 3: 自动批量确认
            SESSION_TRANSACTED = 0:事务提交并确认
             */
            Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);

            // 创建目标(主题或队列)
            Destination destination = session.createQueue("test.ouyangjun");

            // 从会话到主题或队列创建MessageProducer
            MessageConsumer messageConsumer = session.createConsumer(destination);

            // 消息消息
            Message message = messageConsumer.receive();
            // 当设置了“客户端手动确认”消息时, 需要通过message.acknowledge();方式确认消费消息
            if (message instanceof TextMessage) {
                TextMessage textMessage = (TextMessage) message;
                String text = textMessage.getText();
                System.out.println("HelloWorldConsumer Text Received: " + text);
            } else {
                System.out.println("HelloWorldConsumer other Received: " + message);
            }

            // 关闭
            messageConsumer.close();
            session.close();
            connection.close();
        } catch (JMSException e) {
            e.printStackTrace();
        }
    }
}

 

第三步:创建一个main方法测试类

package com.oysept.queues;

public class Test {
    public static void main(String[] args) {
        HelloWorldProducer producer = new HelloWorldProducer();
        HelloWorldConsumer consumer = new HelloWorldConsumer();

        // 生产消息
        producer.producer();
        // 消费消息
        consumer.consumer();
    }
}

执行main方法之后,可到浏览器中刷新ActiveMQ页面

 

三)ActiveMQ Topics发布订阅模式

第一步:创建一个消息生产者

package com.oysept.topics;

import org.apache.activemq.ActiveMQConnectionFactory;

import javax.jms.*;

public class TopicsProducer {
    public static void main(String[] args) {
        ActiveMQConnectionFactory connectionFactory = null;
        Connection connection = null;
        try {
            connectionFactory = new ActiveMQConnectionFactory("admin", "admin", "tcp://localhost:61616");
            connection = connectionFactory.createConnection();
            connection.start();

            Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
            Destination destination = session.createTopic("topic-ouyangjun");
            MessageProducer producer = session.createProducer(destination);

            // 循环发送消息
            for (int i = 0; i < 100; i++) {
                TextMessage message = session.createTextMessage("Message #" + i);
                System.out.println("Sending message #" + i);
                producer.send(message);
                Thread.sleep(100); // 休眠100毫秒
            }
            // 发送一个END消息
            producer.send(session.createTextMessage("END"));

            // 关闭
            producer.close();
            session.close();
        } catch (Exception e) {
            System.out.println("Caught exception!");
        } finally {
            if (connection != null) {
                try {
                    connection.close();
                } catch (JMSException e) {
                    System.out.println("Could not close an open connection...");
                }
            }
        }
    }
}

 

第二步:创建一个消息消费者

package com.oysept.topics;

import org.apache.activemq.ActiveMQConnectionFactory;

import javax.jms.*;
import java.util.concurrent.CountDownLatch;

/**
 * 消费者使用监听器方式
 */
public class TopicsConsumer implements MessageListener {

    // 消费消息的方式
    private final CountDownLatch countDownLatch;
    public TopicsConsumer(CountDownLatch latch) {
        this.countDownLatch = latch;
    }

    @Override
    public void onMessage(Message message) {
        try {
            if (message instanceof TextMessage) {
                String text = ((TextMessage) message).getText();
                if ("END".equalsIgnoreCase(text)) { // 当收到"END"消息时, 就停止消费, 否则会一直处于等待生产者生产消息
                    System.out.println("Received END message!");
                    countDownLatch.countDown();
                } else {
                    System.out.println("Received message:" +text);
                }
            }
        } catch (JMSException e) {
            System.out.println("Got a JMS Exception!");
        }
    }

    public static void main(String[] args) {
        ActiveMQConnectionFactory connectionFactory = null;
        Connection connection = null;
        final CountDownLatch latch = new CountDownLatch(1); // 设置消费者消息的状态, 1表示新建

        try {
            connectionFactory = new ActiveMQConnectionFactory("admin", "admin", "tcp://localhost:61616");;
            connection = connectionFactory.createConnection();
            connection.start();

            Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
            Destination destination = session.createTopic("topic-ouyangjun");

            MessageConsumer consumer = session.createConsumer(destination);
            consumer.setMessageListener(new TopicsConsumer(latch)); // 设置一个监听器

            latch.await();
            consumer.close();
            session.close();
        } catch (Exception e) {
            System.out.println("Caught exception!");
        } finally {
            if (connection != null) {
                try {
                    connection.close();
                } catch (JMSException e) {
                    System.out.println("Could not close an open connection...");
                }
            }
        }
    }
}

测试步骤:

先启动TopicsConsumer消费者监听器,再启动TopicsProducer生产者。

 

识别二维码关注个人微信公众号

本章完结,待续,欢迎转载!
 
本文说明:该文章属于原创,如需转载,请标明文章转载来源!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值