文章目录
1.环境安装准备
1.1 虚拟机准备
1.2 安装配置 jdk8
- 上传jdk压缩文件
将文件jdk-8u212-linux-x64.tar.gz上传到 /root 目录
- 解压缩
执行解压命令
# 将jdk解压到 /usr/local/ 目录
tar -xf jdk-8u212-linux-x64.tar.gz -C /usr/local/
# 切换到 /usr/local/ 目录, 显示列表, 查看解压缩的jdk目录
cd /usr/local
ll
- 配置环境变量
修改 /etc/profile 配置文件, 配置环境变量
vim /etc/profile
# 在文件末尾添加以下内容:
export JAVA_HOME=/usr/local/jdk1.8.0_212
export PATH=$JAVA_HOME/bin:$PATH
修改完后, 让环境变量立即生效
source /etc/profile
- 验证
java -version
----------------------------------------------------------------
java version "1.8.0_212"
Java(TM) SE Runtime Environment (build 1.8.0_212-b10)
Java HotSpot(TM) 64-Bit Server VM (build 25.212-b10, mixed mode)
javac -version
---------------
javac 1.8.0_212
2.安装 RocketMQ
2.1 准备安装文件
- 下载 rocketmq 二进制文件
wget --no-check-certificate https://dlcdn.apache.org/rocketmq/4.9.2/rocketmq-all-4.9.2-bin-release.zip
- 解压缩 rocketmq
回到root目录下,将 rocketmq 解压到 /usr/local/ 目录
unzip rocketmq-all-4.9.2-bin-release.zip -d /usr/local/
# 修改一下文件夹名,改成 rocketmq 方便使用
mv /usr/local/rocketmq-4.9.2 /usr/local/rocketmq
2.2 相关配置变更
- 配置环境变量 ROCKETMQ_HOME 和 PATH
为了后续操作方便可以配置环境变量,之后在任意位置都可以执行rocketmq的操作命令。
vim /etc/profile
# 在文件末尾添加以下内容:
export ROCKETMQ_HOME=/usr/local/rocketmq
export PATH=$ROCKETMQ_HOME/bin:$PATH
修改完后, 让环境变量立即生效
source /etc/profile
- 减小 rocketmq 使用的内存
rocketmq需要启动两个服务: name server
和 broker
, name server
默认配置JVM使用的内存是4g, broker
默认配置JVM使用的内存是8g.
开发环境中如果内存不足, 服务可能会无法启动, 可以通过降低两个服务的内存, 使服务可以正常启动, 也可以节省内存.
修改 name server 内存改为 256m
cd /usr/local/rocketmq/
# 编辑 bin/runserver.sh
vim bin/runserver.sh
# 找到文件中下面这一行:
JAVA_OPT="${JAVA_OPT} -server -Xms4g -Xmx4g -Xmn2g -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m"
# 将 -Xms4g -Xmx4g -Xmn2g 修改为 -Xms256m -Xmx256m -Xmn128m
JAVA_OPT="${JAVA_OPT} -server -Xms256m -Xmx256m -Xmn128m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m"
修改 broker 内存改为 256m
# 编辑 bin/runbroker.sh
vim bin/runbroker.sh
# 找到文件中下面这一行:
JAVA_OPT="${JAVA_OPT} -server -Xms8g -Xmx8g"
# 将 -Xms8g -Xmx8g -Xmn4g 修改为 -Xms256m -Xmx256m
JAVA_OPT="${JAVA_OPT} -server -Xms256m -Xmx256m"
2.3 rocketmq启动
先启动 name server
# 进入 rocketmq 目录
cd /usr/local/rocketmq/
# 启动 name server
nohup sh bin/mqnamesrv &
# 查看运行日志, 看到"The Name Server boot success."表示启动成功
tail -f ~/logs/rocketmqlogs/namesrv.log
再启动 broker
# 启动 broker, 连接name server: localhost:9876
nohup sh bin/mqbroker -n localhost:9876 &
# 查看运行日志, 看到"The broker[......:10911] boot success."表示启动成功
tail -f ~/logs/rocketmqlogs/broker.log
- 关闭防火墙
rocketmq的通信会用到多个端口, 为了方便测试我们关闭防火墙
# 关闭防火墙
systemctl stop firewalld.service
# 禁止防火墙开机启动
systemctl disable firewalld.service
2.4 rocketmq测试
运行测试, 启动生产者发送消息, 启动消费者接收消息
# 通过环境变量, 告诉客户端程序name server的地址
export NAMESRV_ADDR=localhost:9876
# 启动生产者来测试发送消息
sh bin/tools.sh org.apache.rocketmq.example.quickstart.Producer
# 启动消费者来测试接收消息
sh bin/tools.sh org.apache.rocketmq.example.quickstart.Consumer
添加环境变量后执行生产者和消费者命令,生产者会发送一千条消息,同样的消费者也也会接收一千条消息,只要命令执行不报错,就是正常的,执行命令后,并不会自动退出,需要使用ctrl+c
来退出;
2.5 RocketMQ 的关闭命令
关闭 broker
mqshutdown broker
关闭 nameserver
mqshutdown namesrv
3.管理界面
在开源项目 rocketmq-dashboard
中提供了rocketmq
的管理界面: 地址为: https://github.com/apache/rocketmq-dashboard
github
在国内访问缓慢, 也可以使用码云的镜像项目, 地址为: https://gitee.com/mirrors_apache/rocketmq-dashboard
3.1 管理界面资源准备
- 克隆项目
cd /usr/local/rocketmq/
# 克隆 rocketmq-dashboard 项目
git clone https://gitee.com/mirrors_apache/rocketmq-dashboard
3.2 maven打包管理界面项目(可忽略)
如果没有安装 maven,请先安装
# 下载 maven
wget --no-check-certificate https://dlcdn.apache.org/maven/maven-3/3.8.4/binaries/apache-maven-3.8.4-bin.tar.gz
# 解压
tar xf apache-maven-3.8.4-bin.tar.gz -C /usr/local/
# 设置环境变量
cat <<EOF > /etc/profile.d/mvn.sh
export PATH=/usr/local/apache-maven-3.8.4/bin:$PATH
EOF
# 让环境变量生效
source /etc/profile.d/mvn.sh
# 检查 maven 是否可运行
mvn -version
打包管理界面项目 rocketmq-dashboard
,打包过程中会下载各种依赖,比较缓慢,请耐心等待
# 进入管理界面项目的文件夹
cd rocketmq-dashboard
# 执行maven 打包命令, 执行时间较长, 请耐心等待
mvn clean package -Dmaven.test.skip=true
3.3 运行启动管理界面
打包的 jar 文件在 target 目录, 进入目录执行jar文件
# 进入 target 目录
cd target
# 运行管理界面
nohup java -jar rocketmq-dashboard-1.0.1-SNAPSHOT.jar --server.port=8080 --rocketmq.config.namesrvAddr=localhost:9876 &
rocketmq的管理界面此前叫 rocketmq-console-ng-1.0.1.jar
,后边改了名字为 rocketmq-dashboard-1.0.1-SNAPSHOT.jar
,如果使用我们提供的jar文件,则启动命令中的名字需要更改;
3.4 访问管理界面:
访问http://192.168.64.161:8080
进入管理界面页面:
此时,我们应该在管理界面看到此前我们更改的正确的网络地址:
如果不是我们此前更改的正确的地址,那么可能是因为此虚拟机内安装了docker镜像,导致虚拟网络地址被注册了,此时需要执行下一小节的相关命令,如果注册正确,则可以忽略下一小节;
4.收发消息出现超时问题
cd /usr/local/rocketmq/
vim conf/broker.conf
末尾添加
brokerIP1=192.168.64.141
关闭 broker 服务
mqshutdown broker
重新使用 broker.conf 配置启动 broker
nohup sh bin/mqbroker -n localhost:9876 -c conf/broker.conf &
5.服务运行检查
此时我们通过jps
命令可以查看目前运行的服务,正确的应该有3个服务:jar(管理界面),NamesrvStartup,BrokerStartup: