linux下安装ActiveMQ服务(消息队列)

简介: linux下安装ActiveMQ服务(消息队列)

操作系统版本:CentOS Linux release 7.8.2003 (Core)

activemq版本:5.14.3

jdk版本:java version "1.7.0_261"

一、简介

ActiveMQ是Apache软件基金会所研发的开源消息中间件;由于ActiveMQ是一个纯Java程序(由Java开发而成),因此只需要操作系统支持Java虚拟机,ActiveMQ便可运行。

二、优缺点

2.1、优点:

  • Apache出品,流行的,能力强劲、开源消息
  • 支持客户端Java, C,C++,C#,Ruby,Perl,Python,PHP
  • 支持协议:OpenWire,Stomp,REST,WS-Notification,XMPP,AMQP

其它优点自行搜索,如需要性能强劲,处理更多 更海量的消息,请选择Kafka

2.2、缺点:

由于历史悠久,历史包袱较多,版本更新很缓慢。集群模式需要依赖Zookeeper实现。最新架构的产品被命名为Apollo,号称下一代ActiveMQ,目前案例较少

2.3、其它

插几句其它的题外话,市面上的MQ(消息队列或称消息中间件)系统有很多,如何选择一般优先考虑以下几方面:

  • 该mq系统的社区氛围是否浓厚,如果你要找的资料通过百度都搜索不到,需要通过一些其它手段(比如科学上网,你懂的)才能找到资料,那一般不会选择该系统
  • mq系统必须是能支持多个客户端多个编程语言的,例:如果看中的mq系统只支持PHP,后期项目因为某些原因要使用JAVA重构,那这个mq系统也要重新选型。等等等等类似的问题。。。。。。

三、安装

3.1、安装jdk,并设置相关环境变量

# 安装jdk1.7版本:``yum -y ``install` `java-1.7.0-openjdk-devel.x86_64`` ``# 设置全局java环境变量,这些变量对linux当中的所有的用户都可以用:``vi` `/etc/profile` `export` `JAVA_HOME=``/usr/lib/jvm/java-1``.7.0-openjdk-1.7.0.241-2.6.20.0.el7_7.x86_64``export` `CLASSPATH=.:$JAVA_HOME``/jre/lib/rt``.jar:$JAVA_HOME``/lib/dt``.jar:$JAVA_HOME``/lib/tools``.jar``export` `PATH=$PATH:$JAVA_HOME``/bin` `# 刷新全局变量,使我们上面的设置立即生效``source` `/etc/profile` `# 查看java版本:``java -version

3.2、安装ActiveMQ

下载

wget http://archive.apache.org/dist/activemq/5.14.3/apache-activemq-5.14.3-bin.tar.gz

如果下载的比较慢,可以自行进入官网的以下地址进行下载

http://archive.apache.org/dist/activemq/

然后将下载好的压缩包上传到linux环境下

安装并启动

# 解压``tar -zxvf ./apache-activemq-5.14.3-bin.tar.gz` `# 进入解压好的activemq目录`` ``cd apache-activemq-5.14.3/bin/`` ` ` ``# 启动服务并让服务一直保持在后台运行`` ``./activemq start `` ` ` ``# 停止服务`` ``./activemq stop`` ` ` ``# 重启服务`` ``./activemq restart`` ` `# 以调试模式启动,并将日志输出到当前窗口``./activemq console

ActiveMQ默认的管理后台

ActiveMQ自带了一个web服务器(jetty,是java开发的),所以也同时自带了一个web版的管理ActiveMQ的UI界面,apache-activemq-5.14.3/conf/jetty.xml 文件里面是jetty服务器的基本配置,例如:jetty.xml里面有默认的端口号配置(端口号默认:8161)****

访问默认的管理后台

ip地址:8161/admin/  默认的用户名和密码都是admin` `#注意:不要忘了在防火墙开通8161端口或直接关闭防火墙,如果是云服务器,记得在 安全组规则 中的 入方向规则,开通8161端口

界面如下:

网络异常,图片无法展示
|

网络异常,图片无法展示
|

在这个后台管理页面可以进行 创建队列、删除队列、往队列里面插入数据等操作,基本都是一些常见的英文单词,相信都能看懂的= =

相关实践学习
消息队列RocketMQ版:基础消息收发功能体验
本实验场景介绍消息队列RocketMQ版的基础消息收发功能,涵盖实例创建、Topic、Group资源创建以及消息收发体验等基础功能模块。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
相关文章
|
25天前
|
Linux 应用服务中间件 Shell
linux系统服务二!
本文详细介绍了Linux系统的启动流程,包括CentOS 7的具体启动步骤,从BIOS自检到加载内核、启动systemd程序等。同时,文章还对比了CentOS 6和CentOS 7的启动流程,分析了启动过程中的耗时情况。接着,文章讲解了Linux的运行级别及其管理命令,systemd的基本概念、优势及常用命令,并提供了自定义systemd启动文件的示例。最后,文章介绍了单用户模式和救援模式的使用方法,包括如何找回忘记的密码和修复启动故障。
42 5
linux系统服务二!
|
25天前
|
Linux 应用服务中间件 Shell
linux系统服务!!!
本文详细介绍了Linux系统(以CentOS7为例)的启动流程,包括BIOS自检、读取MBR信息、加载Grub菜单、加载内核及驱动程序、启动systemd程序加载必要文件等五个主要步骤。同时,文章还对比了CentOS6和CentOS7的启动流程图,并分析了启动流程的耗时。此外,文中还讲解了Linux的运行级别、systemd的基本概念及其优势,以及如何使用systemd管理服务。最后,文章提供了单用户模式和救援模式的实战案例,帮助读者理解如何在系统启动出现问题时进行修复。
43 3
linux系统服务!!!
|
4月前
|
Linux
在Linux中,怎么把脚本添加到系统服务里,即用 service 来调用?
在Linux中,怎么把脚本添加到系统服务里,即用 service 来调用?
|
29天前
|
Linux 数据库
Linux服务如何实现服务器重启后的服务延迟自启动?
【10月更文挑战第25天】Linux服务如何实现服务器重启后的服务延迟自启动?
145 3
|
29天前
|
关系型数据库 MySQL Linux
Linux系统如何设置自启动服务在MySQL数据库启动后执行?
【10月更文挑战第25天】Linux系统如何设置自启动服务在MySQL数据库启动后执行?
74 3
|
2月前
|
Ubuntu Linux 网络安全
Linux中服务管理问题
【10月更文挑战第4天】
26 2
|
2月前
|
应用服务中间件 Linux Shell
Linux 配置 Nginx 服务的详细步骤,绝对干货
Linux 配置 Nginx 服务的详细步骤,绝对干货
78 0
|
3月前
|
NoSQL Linux Redis
Linux Redis 服务设置开机自启动
【9月更文挑战第2天】在 Linux 系统中,可使用两种方法设置 Redis 开机自启动:一是通过创建 `redis.service` 文件并利用 systemd 进行管理,包括定义服务参数和启动脚本;二是编辑 `/etc/rc.local` 文件,在其中添加启动命令。推荐使用 systemd 方法,因为它更符合现代 Linux 系统的设计理念。设置完成后,可通过 `sudo systemctl status redis.service` 检查服务状态。
437 3
|
3月前
|
编解码 Linux 开发工具
Linux平台x86_64|aarch64架构RTMP推送|轻量级RTSP服务模块集成说明
支持x64_64架构、aarch64架构(需要glibc-2.21及以上版本的Linux系统, 需要libX11.so.6, 需要GLib–2.0, 需安装 libstdc++.so.6.0.21、GLIBCXX_3.4.21、 CXXABI_1.3.9)。
|
4月前
|
消息中间件 Linux 开发者
Linux进程间通信秘籍:管道、消息队列、信号量,一文让你彻底解锁!
【8月更文挑战第25天】本文概述了Linux系统中常用的五种进程间通信(IPC)模式:管道、消息队列、信号量、共享内存与套接字。通过示例代码展示了每种模式的应用场景。了解这些IPC机制及其特点有助于开发者根据具体需求选择合适的通信方式,促进多进程间的高效协作。
176 3