概念
ActiveMQ全称Active Message Queue,是一门实现JMS(Java Message Service)规范的技术,因此ActiveMQ就可以简单的理解为是一个消息队列,与普通队列不同,这个队列可以把消息单独存起来,例如群发消息,当然可以使用Mysql进行实现,但是那样性能消耗太大,且Mysql不适合专门做消息的保存,这个技术就可以实现,当一个用户建立连接时,便给他发送存在服务器上的消息,有句话叫做:术业有专攻,说的就是如此。
ActiveMQ有两种消息模式:
消息-订阅模式:
可以看做是群聊,我发消息到群聊,如果你不在线,当你上线时,你就能看到消息。当把消息推送到服务器上时,有客户端进行连接,便把消息推送,可以看做是1-n。
点对点模式:
可以看做是私人聊天,我给你发消息,你接受消息。可以看做是1-1。
示例:
先启动ActiveMQ
浏览器输入:http://localhost:8161/admin,输入账号和密码admin和admin
点击Queues, 可以看到现在还没有任何一条消息
发送消息
package com.activemq;
import org.apache.activemq.ActiveMQConnectionFactory;
import javax.jms.*;
/**
* 发送消息
* @author 小书包
* @date 2018/12/9 21:52
*/
public class Sender {
// 用户名
public static final String USERNAME = ActiveMQConnectionFactory.DEFAULT_USER;
//密码
public static final String PASSWORD = ActiveMQConnectionFactory.DEFAULT_PASSWORD;
//连接URL
public static final String BROKE_URL = ActiveMQConnectionFactory.DEFAULT_BROKER_URL;
public static void main(String[] args) throws Exception {
//实例化连接工厂
ConnectionFactory factory = new ActiveMQConnectionFactory(USERNAME, PASSWORD, BROKE_URL);
//创建连接
Connection connection = factory.createConnection();
connection.start(); // 启动连接
//创建会话
Session session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
//创建目的地
Queue destination = session.createQueue("test");
//创建生产者
MessageProducer producer = session.createProducer(destination);
//开始发送五条消息
for (int i = 0; i < 5; i++) {
//文本对象
TextMessage message = session.createTextMessage();
//给对象设置文本
message.setText("Hello,World! id = " + i);
//发送消息
producer.send(message);
}
//提交事务
session.commit();
//关闭连接,其他的连接会自动递归关闭
if (connection != null) {
connection.close();
}
}
}
执行完毕,看网页消息条数发生了改变
接收消息
package com.activemq;
import org.apache.activemq.ActiveMQConnectionFactory;
import javax.jms.*;
/**
* 发送消息
*
* @author 小书包
* @date 2018/12/9 21:52
*/
public class Consumer {
// 用户名
public static final String USERNAME = ActiveMQConnectionFactory.DEFAULT_USER;
//密码
public static final String PASSWORD = ActiveMQConnectionFactory.DEFAULT_PASSWORD;
//连接URL
public static final String BROKE_URL = ActiveMQConnectionFactory.DEFAULT_BROKER_URL;
public static void main(String[] args) throws Exception {
//实例化连接工厂
ConnectionFactory factory = new ActiveMQConnectionFactory(USERNAME, PASSWORD, BROKE_URL);
//创建连接
Connection connection = factory.createConnection();
connection.start(); // 启动连接
//创建会话
Session session = connection.createSession(Boolean.FALSE, Session.AUTO_ACKNOWLEDGE);
//创建目的地
Queue destination = session.createQueue("test");
//创建生产者
MessageConsumer consumer = session.createConsumer(destination);
//依次从队列中取值
while (true) {
TextMessage message = (TextMessage) consumer.receive(1000);
if (message == null) {
break;
}
System.out.println(message.getText());
}
//关闭连接,其他的连接会自动递归关闭
if (connection != null) {
connection.close();
}
}
}
控制台输出:
INFO | Successfully connected to tcp://localhost:61616
Hello,World! id = 0
Hello,World! id = 1
Hello,World! id = 2
Hello,World! id = 3
Hello,World! id = 4