入门概述
MQ 种类和对比
MQ 就是消息中间件。MQ 是一种理念,ActiveMQ 是 MQ 的落地产品。不管是哪款消息中间件,都有如下一些技术维度:
MQ 消息的详细比较
各类 MQ 的擅长领域
MQ 种类 | 变成语言 | 擅长领域 |
---|---|---|
kafka | scala | 大数据领域的主流 MQ。 |
rabbitmq | erlang | 基于 erlang 语言,不好修改底层,不好查找问题的原因,不建议选用 |
rocketmq | java | 适用于大型项目。适用于集群 |
activemq | java | 适用于中小型项目 |
### 是什么 |
面向消息的中间件(message-oriented middleware)MOM 能够很好的解决以上问题。是指利用高效可靠的消息传递机制与平台无关的数据交流,并基于数据通信来进行分布式系统的集成。通过提供消息传递和消息排队模型在分布式环境下提供应用解耦,弹性伸缩,冗余存储、流量削峰,异步通信,数据同步等功能。
大致的过程是这样的:发送者把消息发送给消息服务器,消息服务器将消息存放在若干队列/主题 topic 中,在合适的时候,消息服务器回将消息转发给接受者。在这个过程中,发送和接收是异步的,也就是发送无需等待,而且发送者和接受者的生命周期也没有必然的关系;尤其在发布 pub/订阅 sub 模式下,也可以完成一对多的通信,即让一个消息有多个接受者。
怎么下载
如何安装与查看控制台
linux 系统直接安装
检查 JAVA 环境
由于 ActiveMQ 是 java 编写的,因此需要有 jdk 的运行环境,检查 Java 版本
java -version
官网下载安装包
凡遇技术,必定官网ActiveMQ (apache.org)
下图中左侧是稳定版,右侧是开发版。
下载 Linux 的版本,因为需要搭建集群服务器
上传安装包到linux服务器
安装包放到/opt 目录下,放在哪个目录没有硬性要求
创建软件安装文件夹
软件安装文件夹,没有路径要求
# 创建软件安装的文件夹 -p 父目录不存在,则循环创建
mkdir -p /software/activeMQ/
解压缩安装包
tar -zxvf apache-activemq-5.14.5-bin.tar.gz
拷贝解压文件
拷贝解压的软件到指定的安装文件夹,直接解压过去也是可以的
cp -r apache-activemq-5.14.5 /software/activeMQ/
普通启动
# 首先要跳转到 %软件的安装目录%/bin 目录下
cd /software/activeMQ/apache-activemq-5.14.5/bin
# 执行启动命令
./activemq start
检查服务是否启动
方式1:检查进程
ps -ef | grep activemq
方式2:检查端口是否被占用
ActiveMQ默认端口是61616
netstat -anp | grep 61616
方式三:换种方式查看端口是否被占用
lsof -i:61616
启动异常排查
cat /software/activeMQ/apache-activemq-5.14.5/data/activemq.log
参考资料
- 官网:ActiveMQ (apache.org)