ActiveMQ

  1. 大纲
  • 启动双击:E:新建文件夹apache-activemq-5.16.1-binapache-activemq-5.16.1inwin64activemq.bat

  • 访问:http://127.0.0.1:8161/admin/
    • 用户名和密码都是:admin
  1. ActiveMQ是什么

    • Apache推出的,开源的,完全支持 JMS1.1 和 J2EE1.4 规范的JMS Provider实现的消息中间件。
  2. 能干什么
    • 主要功能:实现 JMS Provider,用来帮助实现高可用、高性能、可伸缩、易用和安全的企业级面向消息服务的系统。
    • 直白来说:一个消息 中间件
    • 异步调用
  3. 特点
    • 很容易集成Tomcat Spring
    • 支持多种语言
    • 支持多种协议
    • 可插拔的体系结构,可以灵活定制、如 消息存储方式、安全管理等
    • 设计上保证了高性能
  4. 消息中间件
    • MOM基本功能:将信息以消息的形式,从一个应用程序传送到另一个或多个应用程序。
    • 主要特点
      • 消息异步接受,类似手机短信的欣慰,消息发送者不需要等待消息接收者的响应。
      • 消息可靠接收,确保消息在中间件可靠保存,只有接收方收到消息后才删除消息。
    • 应用场景
      • 在多个系统间进行整合和通讯的时候,通常会要求:
        • 可靠传输:数据不能丢失,有的时候,也会要求不能重复传输。
        • 异步传输:否则各个系统同步发送接受数据,互相等待,造成系统瓶颈。
  5. 基本使用

    • 控制台展示


  1. MQ存数取数
    • 放入至MQ中
      • Map<String, Object> stringObjectMap = activeMQUtil.mQUtil(bms);
      • 返回: success
    • 在MQ中取出
      • 收到消息:message--Bms{chargingStationId='CAGDBF016108', chargingPileId='0107011106032414', timeStamp='2021-03-19 16:30:04', SOC=60, leftTime='2021-03-16 10:10:10', Voltage=234.0, Current=112.0, voltageMin=2.0, voltageMax=4.0, degreeMin=25.0, degreeMax=38.0, carNo='蒙A50219', equipmentStatusTime='2021-03-16 10:10:10'}

  1. 项目中添加使用的工具类
package com.example.demo.util;

import com.example.demo.pojo.Bms;
import com.example.demo.pojo.Staff;
import org.apache.activemq.ActiveMQConnectionFactory;
import org.springframework.stereotype.Repository;

import javax.jms.*;
import java.util.HashMap;
import java.util.Map;

/**
 * @ClassName activeMQUtil
 * @Description ActiveMQ
 * @Author CodeSheep
 * @Date 2020/10/27 15:46
 * @Version V1.0
 * @Package com.example.demo.util
 * 消费者连接 {@link consumer}
 * 生产者连接 {@link producer}
 */
@Repository
public class ActiveMQUtil {
    public Map<String, Object> mQUtil(Bms bms) throws Exception {
        Map<String, Object> map = new HashMap<>();
        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://127.0.0.1:61616");
        Connection connection = connectionFactory.createConnection();
        connection.start();

        Session session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
        Destination destination = session.createQueue("my-queue");

        MessageProducer producer = session.createProducer(destination);
        for (int i = 0; i < 1; i++) {
            TextMessage message = session.createTextMessage("message--" + bms);
            Thread.sleep(1000);
            //通过消息生产者发出消息
            producer.send(message);
        }
        session.commit();
        session.close();
        connection.close();
        map.put("ActiveMQ", "success");
        return map;
    }
}

  1. 生产者测试
package com.example.demo.util;

import org.apache.activemq.ActiveMQConnectionFactory;

import javax.jms.*;

/**
 * @ClassName producer
 * @Description ActiveMQ
 * @Author CodeSheep
 * @Date 2020/10/27 15:16
 * @Version V1.0
 * @Package com.example.demo.util
 */
public class producer {
    public static void main(String[] args) throws Exception {
        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://127.0.0.1:61616");
        Connection connection = connectionFactory.createConnection();
        connection.start();

        Session session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
        Destination destination = session.createQueue("my-queue");

        MessageProducer producer = session.createProducer(destination);
        for (int i = 0; i < 1; i++) {
            TextMessage message = session.createTextMessage("于老板--" + i);
            Thread.sleep(1000);
            //通过消息生产者发出消息
            producer.send(message);
        }
        session.commit();
        session.close();
        connection.close();

    }
}

  1. 消费者测试
package com.example.demo.util;

import org.apache.activemq.ActiveMQConnectionFactory;

import javax.jms.*;

/**
 * @ClassName consumer
 * @Description consumer
 * @Author CodeSheep
 * @Date 2020/10/27 15:37
 * @Version V1.0
 * @Package com.example.demo.util
 */
public class consumer {
    public static void main(String[] args) throws JMSException {
        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://127.0.0.1:61616");
        Connection connection = connectionFactory.createConnection();
        connection.start();

        final Session session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
        Destination destination = session.createQueue("my-queue");

        MessageConsumer consumer = session.createConsumer(destination);
        Integer i = 0;
        while (i < 1) {
            i++;
            TextMessage message = (TextMessage) consumer.receive();
            session.commit();
            System.out.println("收到消息:" + message.getText());
        }
        session.close();
        connection.close();
    }
}
原文地址:https://www.cnblogs.com/Twittery/p/14956210.html