activeMQ Jms Demo

女爷i 2022-05-31 11:55 357阅读 0赞

概述

ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线。ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现,尽管JMS规范出台已经是很久的事情了,但是JMS在当今的J2EE应用中间仍然扮演着特殊的地位

详细

代码下载:http://www.demodashi.com/demo/11680.html

一、什么是ActiveMQ

  百度解释:

  ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线。ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provider实现,尽管JMS规范出台已经是很久的事情了,但是JMS在当今的J2EE应用中间仍然扮演着特殊的地位。

  https://baike.baidu.com/item/ActiveMQ/7889688?fr=aladdin

二、安装ActiveMQ

  windows

  访问ActiveMQ官网下载ActiveMq

  http://activemq.apache.org/

  1505358323759043061.png

  下载完毕后,直接解压即可,然后进入bin目录,选择运行位数(32位,64位)

  1)可以点击InstallService.bat 直接启动

  2)也可以点击activemq.bat 安装到window服务,每次电脑启动时就会自动启动

  1505358323812090776.png

  1505358323877041860.png

三、访问ActiveMQ

  打开浏览器输入:http://127.0.0.1:8161 如下图,登录的名称和密码都是:admin

  1505358323916094195.png

  1505358323940084404.png

  看到上图即代表登录成功了!!!

四、编写demo代码

Maven项目结构:

image.png

代码截图:

image.png

pom.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  5. <modelVersion>4.0.0</modelVersion>
  6. <groupId>com.zy.jms</groupId>
  7. <artifactId>jms</artifactId>
  8. <version>1.0-SNAPSHOT</version>
  9. <dependencies>
  10. <dependency>
  11. <groupId>org.apache.activemq</groupId>
  12. <artifactId>activemq-all</artifactId>
  13. <version>5.9.0</version>
  14. </dependency>
  15. </dependencies>
  16. </project>

生产者:AppProducer

  1. package com.zy.jsm.queue;
  2. import org.apache.activemq.ActiveMQConnectionFactory;
  3. import javax.jms.*;
  4. /**
  5. * Created by Yan on 2017/9/12.
  6. */
  7. public class AppProducer {
  8. private static final String url = "tcp://127.0.0.1:61616";
  9. private static final String queueName = "queue_message";
  10. public static void main(String[] args) throws JMSException {
  11. //1.创建连接工场
  12. ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(url);
  13. //2.创建连接
  14. Connection connection = connectionFactory.createConnection();
  15. //3.启动连接
  16. connection.start();
  17. //4.创建会话
  18. Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
  19. //5.创建一个目标
  20. Destination destination = session.createTopic(queueName);
  21. //6.创建生产者
  22. MessageProducer producer = session.createProducer(destination);
  23. producer.setDeliveryMode(DeliveryMode.PERSISTENT);
  24. for (int i = 0; i < 100; i++) {
  25. //7.创建消息
  26. TextMessage textMessage = session.createTextMessage("activeMQ" + i);
  27. producer.send(textMessage);
  28. }
  29. System.out.print("所有消息已经全部发送完了");
  30. connection.close();
  31. }
  32. }

消费者:AppCusumer

  1. package com.zy.jsm.queue;
  2. import org.apache.activemq.ActiveMQConnectionFactory;
  3. import javax.jms.*;
  4. /**
  5. * Created by Yan on 2017/9/12.
  6. */
  7. public class AppConsumer {
  8. private static final String url = "tcp://127.0.0.1:61616";
  9. private static final String queueName = "queue_message";
  10. public static void main(String[] args) throws JMSException {
  11. //1.创建连接工场
  12. ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(url);
  13. //2.创建连接
  14. Connection connection = connectionFactory.createConnection();
  15. //3.启动连接
  16. connection.start();
  17. //4.创建会话
  18. Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
  19. //5.创建一个目标
  20. Destination destination = session.createQueue(queueName);
  21. //6.创建消费者
  22. MessageConsumer consumer = session.createConsumer(destination);
  23. //7.创建一个监听器
  24. consumer.setMessageListener(new MessageListener() {
  25. public void onMessage(Message message) {
  26. TextMessage textMessage = (TextMessage) message;
  27. try {
  28. System.out.println("接收消息:" + textMessage.getText());
  29. } catch (JMSException e) {
  30. e.printStackTrace();
  31. }
  32. }
  33. });
  34. //connection.close();
  35. }
  36. }

五、说明

  代码是演示的队列模式,还有一种是主题模式

  如果要用主题模式可以修改代码码如下:

  Destination destination = session.createQueue(queueName);

  改为:

  Destination destination = session.createTopic(topicName);

  即可!!!

  设置持久化:

  producer.setDeliveryModel(DeliveryMode.PERSISTENT);

六、比较

  队列模式:在点对点的传输方式中,消息数据被持久化,每条消息都能被消费,没有监听QUEUE地址也能被消费,数据不会丢失,一对一的发布接受策略,保证数据完整。

  主题模式:在发布订阅消息方式中,消息是无状态的,不保证每条消息被消费,只有监听该TOPIC地址才能收到消息并消费,否则该消息将会丢失。一对多的发布接受策略,可以同时消费多个消息。

代码下载:http://www.demodashi.com/demo/11680.html

注:本文著作权归作者,由demo大师发表,拒绝转载,转载需要作者授权

发表评论

表情:
评论列表 (有 0 条评论,357人围观)

还没有评论,来说两句吧...

相关阅读

    相关 JMS-ActiveMQ系列

    个人总结:消息队列,ActiveMQ现在的企业用得很广泛,分点对点(生产消费),发布/订阅两种。现开发的爬虫系统,多个worker抓取到的信息发到mq,mq监听器把信息异步存到

    相关 activeMQ Jms Demo

    概述 ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线。ActiveMQ 是一个完全支持JMS1.1和J2EE 1.4规范的 JMS Provide

    相关 JMS操作ActiveMQ

    一般情况下我们都是通过jms操作mq,如果使用原生的jms代码比较繁琐,还好spring有集成的jms,通过jms模板类,能够适应各种mq的操作,其就像jdbc模板一样将具体的