第一步:下载mq,win10安装教程

www.baidu.com

1.启动activemq,并进入网站 http://127.0.0.1:8161/,打开mq网站,可查看相关队列信息

2.点击 Manage ActiveMQ broker,登陆账号密码均为 admin

Java中使用mq java mq使用_System


第二步:idea创建maven工程,加入依赖如下:

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

第三步:编写代码块,首先明确,activemq分两大模式,主题模式和队列模式,

一、队列模式

1.编写生产者代码

public class AppProducer {

    private static final  String url="tcp://192.168.0.102:61616"; //61616是mq的默认端口
    private static final  String queue="queue-test";//队列名字

    public static void main(String[] args) throws JMSException {
        //1.创建ConnectionFactory(连接工厂)
        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(url);
        //2.创建connect(连接)
        Connection connection = connectionFactory.createConnection();
        //3.启动连接
        connection.start();
        //4.创建会话,俩参数
        Session session= connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
        //5.目的地,消息发送的地方
        Destination destination = session.createQueue(queue);
        //6.创建生产者,向目的地发送消息
        MessageProducer producer = session.createProducer(destination);
        //循环的发送消息
        for(int i=0;i<100;i++){
            //7.创建消息
            TextMessage textMessage = session.createTextMessage("test"+i);
            //8.发布消息
            producer.send(textMessage);
            System.out.println("发送消息 = " + textMessage);
        }
        //9.关闭连接
        connection.close();
    }
}

2.编写消费者代码

public class AppConsumer {
    private static final  String url="tcp://192.168.0.102:61616"; //61616是mq的默认端口
    private static final  String queue="queue-test";//队列名字

    public static void main(String[] args) throws JMSException {
        //1.创建ConnectionFactory(连接工厂)
        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(url);
        //2.创建connect(连接)
        Connection connection = connectionFactory.createConnection();
        //3.启动连接
        connection.start();
        //4.创建会话,俩参数
        Session session= connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
        //5.目的地,消息发送的地方
        Destination destination = session.createQueue(queue);
        //6.创建消费者,去目的地取消息
        MessageConsumer consumer = session.createConsumer(destination);
        //7.消费者监听消费信息,创建一个监听器
        consumer.setMessageListener(new MessageListener() {
            public void onMessage(Message message) {
                TextMessage textMessage = (TextMessage) message;
                System.out.println("接受消息 = " + textMessage);
            }
        });
        //8.关闭连接
        //connection.close();
    }
}





二、主题模式

1.发布者代码

/**
 * 主题模式 发布者
 */
public class AppProducer {

    private static final  String url="tcp://192.168.0.102:61616"; //61616是mq的默认端口
    private static final  String topicName="topic-test";//队列名字

    public static void main(String[] args) throws JMSException {
        //1.创建ConnectionFactory(连接工厂)
        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(url);
        //2.创建connect(连接)
        Connection connection = connectionFactory.createConnection();
        //3.启动连接
        connection.start();
        //4.创建会话,俩参数
        Session session= connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
        //5.目的地,消息发送的地方
        Destination destination = session.createTopic(topicName);
        //6.创建生产者,向目的地发送消息
        MessageProducer producer = session.createProducer(destination);
        //循环的发送消息
        for(int i=0;i<100;i++){
            //7.创建消息
            TextMessage textMessage = session.createTextMessage("test"+i);
            //8.发布消息
            producer.send(textMessage);
            System.out.println("发送消息 = " + textMessage);
        }
        //9.关闭连接
        connection.close();
    }
}

2.订阅者代码

/**
 * 主题模式 订阅者,必须要先订阅(通俗点,就是要先启动订阅者,再启动发布者),发布者发布的消息(订阅者)才能收到
 */
public class AppConsumer {
    private static final  String url="tcp://192.168.0.102:61616"; //61616是mq的默认端口
    private static final  String topicName="topic-test";//队列名字

    public static void main(String[] args) throws JMSException {
        //1.创建ConnectionFactory(连接工厂)
        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(url);
        //2.创建connect(连接)
        Connection connection = connectionFactory.createConnection();
        //3.启动连接
        connection.start();
        //4.创建会话,俩参数
        Session session= connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
        //5.目的地,消息发送的地方
        Destination destination = session.createTopic(topicName);
        //6.创建消费者,去目的地取消息
        MessageConsumer consumer = session.createConsumer(destination);
        //7.消费者监听消费信息,创建一个监听器
        consumer.setMessageListener(new MessageListener() {
            public void onMessage(Message message) {
                TextMessage textMessage = (TextMessage) message;
                System.out.println("接受消息 = " + textMessage);
            }
        });
        //8.关闭连接
        //connection.close();
    }

按照注释里一步一步地看就行了,简单的使用就到此结束了。