第一步:下载mq,win10安装教程
www.baidu.com
1.启动activemq,并进入网站 http://127.0.0.1:8161/,打开mq网站,可查看相关队列信息
2.点击 Manage ActiveMQ broker,登陆账号密码均为 admin
第二步: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();
}
按照注释里一步一步地看就行了,简单的使用就到此结束了。