ActiveMQ简易入门

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ActiveMQ简易入门相关的知识,希望对你有一定的参考价值。

ActiveMQ官方下载地址:http://activemq.apache.org/download.html


下载解压后,执行bin目录下activemq.bat启动mq服务

技术分享图片


找到lib目录并引入相关jar包

技术分享图片


Sender消息发送者类

package com.ycj.activemq;

import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.DeliveryMode;
import javax.jms.Destination;
import javax.jms.JMSException;
import javax.jms.Message;
import javax.jms.MessageProducer;
import javax.jms.Session;

import org.apache.activemq.ActiveMQConnectionFactory;

public class Sender {
    private static final String MQ_USER = "admin";
	private static final String MQ_PWD = "admin";
	private static final String MQ_URL = "tcp://localhost:61616";
	private static final String MQ_QUEUE_DEFAULT = "testQueue";
	
	public static void main(String[] args) throws JMSException {
		// 创建JMS连接工厂
		ConnectionFactory factory = new ActiveMQConnectionFactory(MQ_USER, MQ_PWD, MQ_URL);
		// 通过工厂获取链接并启动
		Connection connection = factory.createConnection();
		connection.start();
		// 创建session
		Session session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
		// 创建destination 消息目的地
		Destination destination = session.createQueue(MQ_QUEUE_DEFAULT);
		// 根据destination初始化一个生产者
		MessageProducer producer = session.createProducer(destination);
		// 生产者消息不持久化
	    producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);
	    // 生成消息 并发送
	    Message msg1 = session.createTextMessage("I'm msg1");
	    Message msg2 = session.createTextMessage("I'm msg2");
	    producer.send(msg1);
	    producer.send(msg2);
	    session.commit();
	    connection.close();
	    System.out.println("producer send msg done!");
	}
}


Receiver消息接收者类

package com.ycj.activemq;

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.ActiveMQConnectionFactory;

public class Receiver {
	private static final String MQ_USER = "admin";
	private static final String MQ_PWD = "admin";
	private static final String MQ_URL = "tcp://localhost:61616";
	private static final String MQ_QUEUE_DEFAULT = "testQueue";
	
	public static void main(String[] args) throws JMSException {
		// 创建JMS连接工厂
		ConnectionFactory factory = new ActiveMQConnectionFactory(MQ_USER, MQ_PWD, MQ_URL);
		// 通过工厂获取链接并启动
		Connection connection = factory.createConnection();
		connection.start();
		// 创建session
		Session session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
		// 创建destination 消息目的地
		Destination destination = session.createQueue(MQ_QUEUE_DEFAULT);
		// 根据destination初始化一个消费者
		MessageConsumer consumer = session.createConsumer(destination);
		while (true) {
          TextMessage msg = (TextMessage) consumer.receive(1000*1000);
          if (null != msg) {
              System.out.println("message has been received:" + msg.getText());
          } 
		}
	}
}


依次运行Receiver和Sender,控制台输出:

Sender

技术分享图片

Receiver

技术分享图片


打开浏览器输入http://localhost:8161/admin/index.jsp,选择Queues可以监控队列消费情况

技术分享图片

以上是关于ActiveMQ简易入门的主要内容,如果未能解决你的问题,请参考以下文章

使用ActiveMQ实现简易聊天功能

ActiveMQ入门案例-生产者代码实现

ActiveMQ入门系列三:发布/订阅模式

ActiveMQ入门:认识并安装ActiveMQ(Windows下)

ActiveMQ + NodeJS + Stomp 极简入门

ActiveMQ + NodeJS + Stomp 极简入门