一、什么是ActiveMQ
百度解释:
ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线。ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现,尽管JMS规范出台已经是很久的事情了,但是JMS在当今的J2EE应用中间仍然扮演着特殊的地位。
二、安装ActiveMq
windows
访问ActiveMQ官网下载ActiveMq
下载完毕后,直接解压即可,然后进入bin目录,选择运行位数(32位,64位)
1)可以点击InstallService.bat 直接启动
2)也可以点击activemq.bat 安装到window服务,每次电脑启动时就会自动启动
三、访问ActiveMQ
打开浏览器输入:http://127.0.0.1:8161 如下图,登录的名称和密码都是:admin
看到上图即代表登录成功了!!!
四、编写demo代码
Maven项目
4.0.0
com.zy.jms
jms
1.0-SNAPSHOT
org.apache.activemq
activemq-all
5.9.0
pom.xml
public classAppConsumer {private static final String url = "tcp://127.0.0.1:61616";private static final String queueName = "queue_message";public static void main(String[] args) throwsJMSException {//1.创建连接工场
ConnectionFactory connectionFactory = newActiveMQConnectionFactory(url);//2.创建连接
Connection connection =connectionFactory.createConnection();//3.启动连接
connection.start();//4.创建会话
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);//5.创建一个目标
Destination destination =session.createQueue(queueName);//6.创建消费者
MessageConsumer consumer =session.createConsumer(destination);//7.创建一个监听器
consumer.setMessageListener(newMessageListener() {public voidonMessage(Message message) {
TextMessage textMessage=(TextMessage) message;try{
System.out.println("接收消息:" +textMessage.getText());
}catch(JMSException e) {
e.printStackTrace();
}
}
});//connection.close();
}
}
AppConsumer.java
public classAppProducer {private static final String url = "tcp://127.0.0.1:61616";private static final String queueName = "queue_message";public static void main(String[] args) throwsJMSException {//1.创建连接工场
ConnectionFactory connectionFactory = newActiveMQConnectionFactory(url);//2.创建连接
Connection connection =connectionFactory.createConnection();//3.启动连接
connection.start();//4.创建会话
Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);//5.创建一个目标
Destination destination =session.createQueue(queueName);//6.创建生产者
MessageProducer producer =session.createProducer(destination);for (int i = 0; i < 100; i++) {//7.创建消息
TextMessage textMessage = session.createTextMessage("activeMQ" +i);
producer.send(textMessage);
}
System.out.print("所有消息已经全部发送完了");
connection.close();
}
}
AppProducer.java
五、说明
代码是演示的队列模式,还有一种是主题模式
如果要用主题模式可以修改代码码如下:
Destination destination = session.createQueue(queueName);
改为:
Destination destination = session.createTopic(topicName);
即可!!!
设置持久化:
producer.setDeliveryModel(DeliveryMode.PERSISTENT);
六、比较
队列模式:在点对点的传输方式中,消息数据被持久化,每条消息都能被消费,没有监听QUEUE地址也能被消费,数据不会丢失,一对一的发布接受策略,保证数据完整。
主题模式:在发布订阅消息方式中,消息是无状态的,不保证每条消息被消费,只有监听该TOPIC地址才能收到消息并消费,否则该消息将会丢失。一对多的发布接受策略,可以同时消费多个消息。