首页 > 其他分享 >activeMQ Jms Demo

activeMQ Jms Demo

时间:2023-06-01 10:06:47浏览次数:45  
标签:activeMQ String 创建 Jms connection session static Demo ActiveMQ


概述


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


详细


一、什么是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/

  

activeMQ Jms Demo_activeMQ Jms

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

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

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

  

activeMQ Jms Demo_xml_02

  

activeMQ Jms Demo_activeMQ Jms_03

三、访问ActiveMQ

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

  

activeMQ Jms Demo_activeMQ Jms_04

  

activeMQ Jms Demo_maven_05

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

四、编写demo代码

Maven项目结构:


activeMQ Jms Demo_xml_06

代码截图:


activeMQ Jms Demo_xml_07

pom.xml


<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.zy.jms</groupId>
    <artifactId>jms</artifactId>
    <version>1.0-SNAPSHOT</version>

    <dependencies>
        <dependency>
            <groupId>org.apache.activemq</groupId>
            <artifactId>activemq-all</artifactId>
            <version>5.9.0</version>
        </dependency>
    </dependencies>

</project>


生产者:AppProducer


package com.zy.jsm.queue;

import org.apache.activemq.ActiveMQConnectionFactory;

import javax.jms.*;

/**
 * Created by Yan on 2017/9/12.
 */
public class AppProducer {

    private static final String url = "tcp://127.0.0.1:61616";
    private static final String queueName = "queue_message";

    public static void main(String[] args) throws JMSException {
        //1.创建连接工场
        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(url);
        //2.创建连接
        Connection connection = connectionFactory.createConnection();
        //3.启动连接
        connection.start();
        //4.创建会话
        Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE);
        //5.创建一个目标
        Destination destination = session.createTopic(queueName);
        //6.创建生产者
        MessageProducer producer = session.createProducer(destination);
        producer.setDeliveryMode(DeliveryMode.PERSISTENT);
        for (int i = 0; i < 100; i++) {
            //7.创建消息
            TextMessage textMessage = session.createTextMessage("activeMQ" + i);
            producer.send(textMessage);
        }
        System.out.print("所有消息已经全部发送完了");
        connection.close();
    }
}

消费者:AppCusumer

package com.zy.jsm.queue;

import org.apache.activemq.ActiveMQConnectionFactory;

import javax.jms.*;

/**
 * Created by Yan on 2017/9/12.
 */
public class AppConsumer {
    private static final String url = "tcp://127.0.0.1:61616";
    private static final String queueName = "queue_message";

    public static void main(String[] args) throws JMSException {
        //1.创建连接工场
        ConnectionFactory connectionFactory = new ActiveMQConnectionFactory(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(new MessageListener() {
            public void onMessage(Message message) {
                TextMessage textMessage = (TextMessage) message;
                try {
                    System.out.println("接收消息:" + textMessage.getText());
                } catch (JMSException e) {
                    e.printStackTrace();
                }
            }
        });
        //connection.close();
    }
}

五、说明

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

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

  Destination destination = session.createQueue(queueName);

  改为:

  Destination destination = session.createTopic(topicName);

  即可!!!

  设置持久化:

  producer.setDeliveryModel(DeliveryMode.PERSISTENT);

六、比较

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

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




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

标签:activeMQ,String,创建,Jms,connection,session,static,Demo,ActiveMQ
From: https://blog.51cto.com/u_7583030/6392431

相关文章

  • activemq安装教程
    https://activemq.apache.org/ 官网下载对应版本:apache-activemq-5.16.3-bin.tar.gztar-xvzfapache-activemq-5.16.3-bin.tar.gzmvapache-activemq-5.16.3/usr/localcdconf/vimactivemq.xml在broker标签上添加schedulerSupport="true"属性。如下:<brokerxmlns="h......
  • python avro 数据格式使用demo
    {"name":"UEProcedures","type":"record","fields":[{"name":"imsi","type":"string"},{"name":"time_at","type":&quo......
  • java轻型内存队列处理demo
    java轻型内存队列处理demo@ComponentpublicclassConcurrentLinkedQueueUtils{staticAtpLogBizatpLogBiz;staticAuditLogtTmpDataServiceauditLogDataService;staticConcurrentLinkedQueueconList=newConcurrentLinkedQueue();privatestaticvo......
  • Blazor 跨平台的、共享一套UI的天气预报 Demo
    1.前言很久之前就读过dotnet9大佬的一篇文章,MAUI与Blazor共享一套UI,媲美Flutter,实现Windows、macOS、Android、iOS、Web通用UI,没读过的可以读一读,写的很好。对Blazor跨平台开始比较感兴趣。渐渐发现BlazorHybrid可以在更多的框架上运行,如Winform、WPF,更有Photino这样可以在......
  • shellcode的一个demo例子
    handy-shellcodeBinaryExploitation,50pointsDescription:Thisprogramexecutesanyshellcodethatyougiveit.Canyouspawnashellandusethattoreadtheflag.txt?#include<stdio.h>#include<stdlib.h>#include<string.h>#include&l......
  • AI demo framework
     importpickleimportmatplotlib.pyplotaspltfromsklearnimportdatasetsfromsklearn.model_selectionimporttrain_test_splitfromsklearn.neighborsimportKNeighborsClassifierfromsklearn.model_selectionimportcross_val_scorefromsklearnimportm......
  • Intel daal4py demo运行过程
    daal安装(记得先安装anaconda):gitclonehttps://github.com/IntelPython/daal4py.gitcddaal4pycondacreate-nDAAL4PY-cintel-cintel/label/test-cconda-forgepython=3.6mpichcnctbb-develdaaldaal-includecythonjinja2numpysourceactivateDAAL4PYexportC......
  • MarkdownDemo
    标题语法与#号键有关,此为二级标题段落要创建段落,请使用空白行将一行或多行文本进行分隔。suchasthis标题似乎自带空白行换行语法在一行的末尾添加两个或多个空格,然后按回车键,即可创建一个换行似乎用处不大(换行还得是回车键)强调语法通过将文本设置为粗体或斜体来强调......
  • U3DFrameWorkDemo:六、网络
    代码参考代码文件参考下述详解的类图,工程参考第零章工程说明概述在多人联机游戏中,大多采用前、后台的架构,前台多表现相关,后台则多交互、资产相关。网络消息的传递其实是由系统内核完成的,大多语言封装了Socket库面向开发者提供网络消息传递的接口,而这里的网络模块是对网络消息传......
  • Multiserver游戏服务器Demo[C++&Lua]
    代码参考代码文件参考下述详解的类图,工程参考第零章工程说明关键特性对Socket库进行封装,抹平Socket的Window&Linux的平台差异。C++嵌入lua脚本,增加开发者编码效率,减少编译时间消耗。非阻塞网络IO多线程任务模型多服务模型详解Socket库封装主要是对C++的Socket库进行......