ActiveMQ消息队列的介绍以及部署

news2025/1/12 23:01:34

文章目录

    • 1.ActiveMQ消息队列中间件
      • 1.1.什么是ActiveMQ
      • 1.2.ActiveMQ支持的消息传递类型
    • 2.部署ActiveMQ消息队列
      • 2.1.安装JDK环境
      • 2.2.部署ActiveMQ消息队列
      • 2.3.启动ActiveMQ消息队列
      • 2.4.ActiveMQ的端口号
      • 2.5.使用ActiveMQ的后台管理系统

ActiveMQ官网:https://activemq.apache.org/

1.ActiveMQ消息队列中间件

1.1.什么是ActiveMQ

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

ActiveMQ的特点:

  1. 支持来自Java,C,C ++,C#,Ruby,Perl,Python,PHP的各种跨语言客户端和协议。
  2. 完全支持JMS客户端和Message Broker中的企业集成模式。
  3. 支持许多高级功能,如消息组,虚拟目标,通配符和复合目标。
  4. 完全支持JMS 1.1和J2EE 1.4,支持瞬态,持久,事务和XA消息。
  5. Spring支持,以便ActiveMQ可以轻松嵌入到Spring应用程序中,并使用Spring的XML配置机制进行配置。
  6. 专为高性能集群,客户端 - 服务器,基于对等的通信而设计。
  7. CXF和Axis支持,以便ActiveMQ可以轻松地放入这些Web服务堆栈中以提供可靠的消息传递。
  8. 可以用作内存JMS提供程序,非常适合单元测试JMS。
  9. 支持可插拔传输协议,例如in-VM,TCP,SSL,NIO,UDP,多播,JGroups和JXTA传输。
  10. 使用JDBC和高性能日志支持非常快速的持久性。

1.2.ActiveMQ支持的消息传递类型

ACtiveMQ支持的消息传递类型有点对点传递、发布/订阅模型

1)点对点传递类型

点对点传递是指:消息发送方(生产者)将数据存储在ActiveMQ的Queue队列中,队列中的消息数据会被消费者进行消费,也就是读取,然后进行业务处理,消费者读取完成数据后会向MQ发送一个确认消费的信息给队列,队列知道数据被消费后就会从队列中将该条数据删除。

image-20220305224043715

点对点传递的特点:

  • 每条消息数据同一时间内只允许存在一个消费者,数据一旦被消费,将不会存在在消息队列中。
  • 生产者和消费者之间在时间上没有依赖性,谁先启动都可以,生产者可以先发送数据到队列,消费者进行读取消费,消费者也可以先启动等待生产者产生数据。
  • 消费者在成功接收到消息之后需要向队列应答成功

2)发布/订阅传递类型

发布/订阅模式下包含三个角色:主题(Topic)、发布者(Publisher)、订阅者(Subscriber),发布者就相当于生产者,订阅者相当于消费者。

image-20220305224423259

发布/订阅模式中,订阅者要先发起Topic的订阅,等待发布者向Topic中写入数据,然后进行订阅消费,只有对Topic有管理的订阅者才可以接收到由发布者产生的数据。

Topic实现发布和订阅功能,多个订阅者可以同时发起一个Topic,当发布消息进入Topic时,所有订阅这个Topic的订阅者都能得到这个消息,类似于一对多。

发布/订阅模型的特点:

  • 每个Topic可以有多个订阅者,同时消费数据。
  • 发布者和订阅者之间有时间上的依赖性,先定义Topic,再发送消息数据。
  • 订阅者必须保持运行状态才能收到发布者的消息数据。

2.部署ActiveMQ消息队列

2.1.安装JDK环境

1.解压jdk源码包
[root@activemq ~]# tar xf jdk1.8.tar.gz -C /usr/local/

2.设置环境变量
[root@activemq ~]# vim /etc/profile
JAVA_HOME=/usr/local/jdk1.8.0_131/
PATH=$JAVA_HOME/bin:$PATH

3.重载配置
[root@activemq ~]# source /etc/profile

4.查看jdk的版本
[root@activemq ~]# java -version
java version "1.8.0_131"
Java(TM) SE Runtime Environment (build 1.8.0_131-b11)
Java HotSpot(TM) 64-Bit Server VM (build 25.131-b11, mixed mode)

2.2.部署ActiveMQ消息队列

1.下载ActiveMQ二进制文件
[root@activemq ~]# wget https://www.apache.org/dyn/closer.cgi?filename=/activemq/5.16.4/apache-activemq-5.16.4-bin.zip&action=download

2.部署ActiveMQ
[root@activemq ~]# mkdir /data
[root@activemq ~]# tar xf apache-activemq-5.16.4-bin.tar.gz -C /data/
[root@activemq ~]# mv /data/apache-activemq-5.16.4 /data/activemq

3.配置ActiveMQ后台管理服务的IP地址
[root@activemq ~]# vim /data/activemq/conf/jetty.xml 
    <bean id="jettyPort" class="org.apache.activemq.web.WebConsolePort" init-method="start">
             <!-- the default port number for the web console -->
        <property name="host" value="0.0.0.0"/>		#119行,将127修改成4个0
        <property name="port" value="8161"/>
    </bean>

2.3.启动ActiveMQ消息队列

1.启动ActiveMQ
[root@activemq ~]# cd /data/activemq
[root@activemq activemq]# ./bin/activemq start
INFO: Loading '/data/activemq//bin/env'
INFO: Using java '/usr/local/jdk1.8.0_131/bin/java'
INFO: Starting - inspect logfiles specified in logging.properties and log4j.properties to get details
INFO: pidfile created : '/data/activemq//data/activemq.pid' (pid '72746')

2.查看ActiveMQ的状态
[root@activemq activemq]# ./bin/activemq status
INFO: Loading '/data/activemq//bin/env'
INFO: Using java '/usr/local/jdk1.8.0_131/bin/java'
ActiveMQ is running (pid '72746')

3.查看ActiveMQ的进程
[root@activemq activemq]# ps aux | grep activemq
root      72746  4.8  5.8 3097116 109052 pts/0  Sl   20:18   0:03 /usr/local/jdk1.8.0_131/bin/java -Xms64M -Xmx1G -Djava.util.logging.config.file=logging.properties -Djava.security.auth.login.config=/data/activemq//conf/login.config -Dcom.sun.management.jmxremote -Djava.awt.headless=true -Djava.io.tmpdir=/data/activemq//tmp -Dactivemq.classpath=/data/activemq//conf:/data/activemq//../lib/: -Dactivemq.home=/data/activemq/ -Dactivemq.base=/data/activemq/ -Dactivemq.conf=/data/activemq//conf -Dactivemq.data=/data/activemq//data -jar /data/activemq//bin/activemq.jar start

4.关闭和重启ActiveMQ
[root@activemq activemq]# ./bin/activemq stop
[root@activemq activemq]# ./bin/activemq restart

5.查看ActiveMQ的日志
[root@activemq ~]#tail -f /data/activemq/data/activemq.log

2.4.ActiveMQ的端口号

[root@activemq ~]# netstat -lnpt | grep java
tcp6       0      0 :::5672                 :::*                    LISTEN      75005/java          
tcp6       0      0 :::61613                :::*                    LISTEN      75005/java          
tcp6       0      0 :::61614                :::*                    LISTEN      75005/java          
tcp6       0      0 :::61616                :::*                    LISTEN      75005/java          
tcp6       0      0 :::1883                 :::*                    LISTEN      75005/java          
tcp6       0      0 :::8161                 :::*                    LISTEN      75005/java          
tcp6       0      0 :::46562                :::*                    LISTEN      75005/java  

ActiveMQ有很多个端口,其中最为主要的就是8161和61616端口。

8161端口:ActiveMQ的后端管理系统使用的端口,可以在浏览器中访问此端口进入后端管理页面。

6161端口:TCP协议端口,用于JAVA程序调用。

2.5.使用ActiveMQ的后台管理系统

1)登陆后台管理系统

ActiveMQ5.6版本之后访问后台管理系统需要先登陆,默认账号密码为admin。

image-20220305203516130

2)后台管理系统页面

点击图中的Manage ActiveMQ broker进入ActiveMQ的管理页面。

image-20220305203804790

3)主要关注Queues和Topic两个界面

image-20220305203939159

image-20220305204437371

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/687523.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

官宣!硬核学科“集成电路与机器人应用开发”正式入驻新校区!

好消息&#xff01;好消息&#xff01; 集成电路与机器人应用开发学科 强势入驻黑马武汉校区 现在报名&#xff08;7月1日前&#xff09;首期班 限时优惠1000元 再送价值千元硬件装备1套&#xff01; 上周&#xff0c;播妞采访了几位2023届毕业生的就业现状&#xff08;点击…

11-12 - 信号发送与处理

---- 整理自狄泰软件唐佐林老师课程 查看所有文章链接&#xff1a;&#xff08;更新中&#xff09;Linux系统编程训练营 - 目录 文章目录 1. 信号的概念及分类1.1 问题1.2 什么是信号1.3 信号的分类1.3.1 硬件异常信号1.3.2 终端相关信号1.3.3 软件相关信号 1.4 内核与信号1.5 …

组合模式(Composite)

别名 对象树&#xff08;Object Tree&#xff09;。 定义 组合是一种结构型设计模式&#xff0c;你可以使用它将对象组合成树状结构&#xff0c;并且能像使用独立对象一样使用它们。 前言 1. 问题 如果应用的核心模型能用树状结构表示&#xff0c;在应用中使用组合模式才…

彭博:为完善Vision Pro体验,苹果扩招数千名新员工

彭博社记者Mark Gurman在最新一期Power On栏目中表示&#xff0c;苹果在WWDC 2023上公布Vision Pro头显&#xff0c;只是该公司进入XR市场的第一步&#xff0c;实际上该设备在明年才会推出完整版。而且据项目相关人士透露&#xff0c;Vision Pro的软件生态还需要很长时间发展。…

软件工程——第6章详细设计知识点整理

本专栏是博主个人笔记&#xff0c;主要目的是利用碎片化的时间来记忆软工知识点&#xff0c;特此声明&#xff01; 文章目录 1.详细设计阶段的根本目的是&#xff1f; 2.详细设计的任务&#xff1f; 3.详细设计的结果地位&#xff1f;如何衡量程序质量&#xff1f; 4.结构程…

在GitHub上爆火!跳槽必看《Java 面试突击核心讲》知识点笔记整理

不知道大家在面试中有没有这种感觉&#xff1a;面试官通常会在短短两小时内对面试者的知识结构进行全面了解&#xff0c;面试者在回答问题时如果拖泥带水且不能直击问题的本质&#xff0c;则很难充分表现自己&#xff0c;最终影响面试结果。 所以针对这种情况&#xff0c;这份…

从0到1精通自动化测试,pytest自动化测试框架,使用自定义标记mark(十一)

一、前言 pytest可以支持自定义标记&#xff0c;自定义标记可以把一个web项目划分多个模块&#xff0c;然后指定模块名称执行 app自动化的时候&#xff0c;如果想android和ios公用一套代码时&#xff0c;也可以使用标记功能&#xff0c;标明哪些是ios用例&#xff0c;哪些是a…

除静电设备给我们的生产带来怎样的便利

一般来说&#xff0c;我们需要根据具体的生产工艺和场景选择适当的静电设备&#xff0c;并按照厂商提供的操作规范正确使用&#xff0c;以确保除静电设备有效发挥作用。 1. 静电消除&#xff1a;静电设备可以帮助消除物体表面的静电电荷&#xff0c;防止静电积聚。静电积聚可能…

UML类图设计

1.普通类&#xff0c;抽象类&#xff0c;接口 普通类 抽象类 接口 1 关联关系 依赖关系 关联&#xff1a;对象之间的引用关系 依赖&#xff1a;耦合性最低&#xff0c;一些静态方法等 2 聚合关系 组合关系 聚合&#xff1a;整体与部分的关系&#xff0c;但是部分可以脱…

英特尔 oneAPI 2023 黑客松大赛:赛道二机器学习:预测淡水质量 实践分享

目录 一、问题描述二、解决方案1、方案简述2、数据分析预处理特征类型处理特征分布分析 3、特征构造4、特征选择过滤法重要性排序 5、模型训练 总结未来工作 一、问题描述 淡水是我们最重要和最稀缺的自然资源之一&#xff0c;仅占地球总水量的 3%。它几乎触及我们日常生活的方…

Python:pyecharts可视化

文章目录 简介Geo地理图绘制折线图区域突出显示横坐标带选择展示 add地图Mapformatter控制value显示在图中显示value值目标html的解析自定义地图js资源原生地图js的解析解决省份上文字不居中的问题 桑基图设置桑基柱的颜色 参考文献 简介 &#xff08;这是20年的笔记&#xff…

医疗陪诊小程序开发功能有哪些?

医疗陪诊系统开发功能有哪些&#xff1f; 1、注册登录。用户初次使用需使用个人手机号码或者是第三方社交账号进行注册登录&#xff0c;登陆之后填写个人相关信息&#xff0c;姓名、性别、年龄、过往病史、病历等信息&#xff0c;以便医生可以根据患者资料进行初步判断。…

小文智能自定义变量详解

在小文交互场景设计时&#xff0c;有一个特殊功能&#xff0c;叫做自定义变量。有时&#xff0c;根据外呼对象的不同&#xff0c;需要对用户传达不同的内容&#xff0c;比如称呼、地址、公司名称等等。此时&#xff0c;就可以使用小文交互的自定义变量功能来实现对不同用户呼出…

Destination unreachable(Port unreachable) 错误原因和解决办法

Destination unreachable(Port unreachable) 是一条由网络设备&#xff08;如路由器或防火墙&#xff09;生成的ICMP&#xff08;Internet Control Message Protocol&#xff09;错误消息&#xff0c;用于通知源设备目标设备或端口无法到达。 一、什么是ICMP ICMP&#xff08;I…

【中危】Guava<32.0.0 存在竞争条件漏洞

漏洞描述 Guava 是 Google 公司开发的开源 Java 代码库&#xff0c;提供常用的Java工具和数据结构。 Guava 1.0 至 31.1 版本中的 FileBackedOutputStream 类使用Java的默认临时目录创建文件&#xff0c;由于创建的文件名容易被攻击者猜测&#xff0c;在 Unix 和 Android Ice…

静电设备在静电处理环节中的原理

静电设备在静电处理环节中发挥着重要的作用。以下是一些常见的静电设备及其作用&#xff1a; 1. 静电消除器&#xff1a;静电消除器通过释放相等数量的正负离子&#xff0c;有效地中和周围环境中的静电荷&#xff0c;从而减少或消除静电引起的问题&#xff0c;例如静电吸附、电…

AI科技的应用革命:改变生活方式、提升人类生产力

人工智能技术的发展和应用&#xff0c;正在对我们的生活方式产生深远的影响。无论是在家庭、工作还是娱乐方面&#xff0c;越来越多的AI工具正在改变我们的习惯、观念和行为。它们为我们提供了更加智能化、个性化和定制化的服务和产品&#xff0c;让我们的生活变得更加便捷、高…

NXP i.MX 8M Plus工业核心板硬件说明书( 四核ARM Cortex-A53 + 单核ARM Cortex-M7,主频1.6GHz)

1 硬件资源 创龙科技SOM-TLIMX8MP是一款基于NXP i.MX 8M Plus的四核ARM Cortex-A53 单核ARM Cortex-M7异构多核处理器设计的高端工业核心板&#xff0c;ARM Cortex-A53(64-bit)主处理单元主频高达1.6GHz&#xff0c;ARM Cortex-M7实时处理单元主频高达800MHz。处理器…

【教程】Flutter与Rust完美交互,无需手写FFI代码

实践环境&#xff1a;Windows11 flutter_rust_bridge官方文档 Flutter环境配置教程 | Rust环境配置教程 新建一个全新的Flutter项目并运行&#xff1a; flutter create example && cd example && flutter run 在Flutter项目根目录新建一个Rust项目&#xf…

从0到1精通自动化,接口自动化测试——数据驱动DDT实战

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 DDT简介 名称&am…