消息队列之ActiveMQ简单环境搭建

时间:2021-05-09 17:05:09

准备:

   环境:win7,Eclipse,jdk1.8

   ActiveMQ版本:ActiveMQ 5.9.0 Release下载地址:http://activemq.apache.org/download-archives.html

开始:

  1.下载完后进行解压,解压完找到其中的activemq-all-5.9.0.jar包.

  2.Eclipse创建一个java项目,导入上面这个jar包

  3.创建生产者和消费者类

消息队列之ActiveMQ简单环境搭建

  生产者

package com.sinosoft.activemq;

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; public class JMSProducer { //默认连接用户名
private static final String USERNAME = ActiveMQConnection.DEFAULT_USER;
//默认连接密码
private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD;
//默认连接地址
private static final String BROKERURL = ActiveMQConnection.DEFAULT_BROKER_URL;
//发送的消息数量
private static final int SENDNUM = 10; public static void main(String[] args) {
//连接工厂
ConnectionFactory connectionFactory;
//连接
Connection connection = null;
//会话,接收或者发送消息的线程
Session session;
//消息的目的地
Destination destination;
//消息生产者
MessageProducer messageProducer;
//实例化连接工厂
connectionFactory = new ActiveMQConnectionFactory(JMSProducer.USERNAME, JMSProducer.PASSWORD, JMSProducer.BROKERURL); try {
//通过连接工厂获取连接
connection = connectionFactory.createConnection();
//启动连接
connection.start();
//创建session
session = connection.createSession(true, Session.AUTO_ACKNOWLEDGE);
//创建一个名称为Hello World!的消息队列
destination = session.createQueue("Hello World");
//创建消息生产者
messageProducer = session.createProducer(destination);
//发送消息
sendMessage(session,messageProducer); session.commit(); } catch (Exception e) {
e.printStackTrace();
} finally{
if(connection != null){
try {
connection.close();
} catch (JMSException e) {
e.printStackTrace();
}
}
} } /**
* 发送消息
* @param session
* @param messageProducer 消息生产者
* @throws Exception
*/
public static void sendMessage(Session session,MessageProducer messageProducer) throws Exception{
for (int i = 0; i < JMSProducer.SENDNUM; i++) {
//创建一条文本消息
TextMessage message = session.createTextMessage("activemq 发送消息:" + i);
System.err.println("发送消息:activemq 发送消息:" + i);
//通过消息生产者发出消息
messageProducer.send(message);
}
} }

  

  消费者

    

package com.sinosoft.activemq;

import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.MessageConsumer;
import javax.jms.Session;
import javax.jms.TextMessage; import org.apache.activemq.ActiveMQConnection;
import org.apache.activemq.ActiveMQConnectionFactory; public class JMSConsumer { //默认连接用户名
private static final String USERNAME = ActiveMQConnection.DEFAULT_USER;
//默认连接密码
private static final String PASSWORD = ActiveMQConnection.DEFAULT_PASSWORD;
//默认连接地址
private static final String BROKERURL = ActiveMQConnection.DEFAULT_BROKER_URL; public static void main(String[] args) {
//连接工厂
ConnectionFactory connectionFactory;
//连接
Connection connection = null;
//会话,接收或者发送消息的线程
Session session;
//消息目的地
Destination destination;
//消息的消费者
MessageConsumer messageConsumer;
//实例化连接工厂
connectionFactory = new ActiveMQConnectionFactory(JMSConsumer.USERNAME, JMSConsumer.PASSWORD, JMSConsumer.BROKERURL); try {
//通过工厂获取连接
connection = connectionFactory.createConnection();
//启动连接
connection.start();
//创建会话
session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
//创建一个连接Hello World!的消息队列
destination = session.createQueue("Hello World");
//创建消息的消费者
messageConsumer = session.createConsumer(destination); while(true){
TextMessage textMessage = (TextMessage) messageConsumer.receive(100000);
if (textMessage != null) {
System.err.println("收到的消息:" + textMessage.getText());
} else {
break;
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
}

  

从解压的压缩包找到bin目录下的activemq.bat并运行它

消息队列之ActiveMQ简单环境搭建

结果应该如下:

  消息队列之ActiveMQ简单环境搭建

然后进入红线标出来的地址,出现下面页面表示已经启动了ActiveMQ的服务

消息队列之ActiveMQ简单环境搭建

刚才运行activemq.bat成功后,默认也运行了activemq-admin.bat,所以进入地址http://localhost:8161/admin/

这时需要输入用户名和密码,都是admin,成功后会进入到以下页面

消息队列之ActiveMQ简单环境搭建

运行生产者类

  控制台如下:

  消息队列之ActiveMQ简单环境搭建

页面上选择queues,发现

消息队列之ActiveMQ简单环境搭建

再运行消费者类后

  控制台

消息队列之ActiveMQ简单环境搭建

再看刷新Queues页面,发现

消息队列之ActiveMQ简单环境搭建

就算是点对点的消息队列发送和接收成功了.

如果将消费者类这里改为true

消息队列之ActiveMQ简单环境搭建

那么最终运行完的结果就是

消息队列之ActiveMQ简单环境搭建

总结,消息队列,任重而道远,需要慢慢探索,技术性东西都是,勤学一时,受用终身