安装包安装
下载:
wget https://mirrors.tuna.tsinghua.edu.cn/apache/rocketmq/4.5.1/rocketmq-all-4.5.1-bin-release.zip
解压:
unzip rocketmq-all-4.5.1-bin-release.zip -d rocketmq-all
进入目录:
cd rocketmq-all-4.5.1-bin-release
调整默认的内存大小参数:
cd bin/
vim runserver.sh
JAVA_OPT="${JAVA_OPT} -server -Xms128m -Xmx128m -Xmn128m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=128m"
vim runbroker.sh
JAVA_OPT="${JAVA_OPT} -server -Xms128m -Xmx128m -Xmn128m"
启动nameserver:
nohup bin/mqnamesrv -n 192.168.56.100:9876 > namesrv.log & #后台启动
# The Name Server boot success. serializeType=JSON 看到这个表示已经提供成功
修改conf/broker.conf,添加:
brokerIP1=192.168.56.100
namesrvAddr=192.168.56.100:9876
启动broker:
nohup bin/mqbroker -c conf/broker.conf > broker.log & #-n 指定nameserver地址和端口
The broker[devops, 192.168.56.100:10911] boot success. serializeType=JSON and name server is 192.168.56.100:9876
发送消息测试:
export NAMESRV_ADDR=192.168.56.100:9876
cd bin
sh tools.sh org.apache.rocketmq.example.quickstart.Producer
测试接收消息:
sh tools.sh org.apache.rocketmq.example.quickstart.Consumer
docker安装
拉取镜像
docker pull foxiswho/rocketmq:server-4.5.1
docker pull foxiswho/rocketmq:broker-4.5.1
创建nameserver容器:
docker create -p 9876:9876 --name rmqserver \
-e "JAVA_OPT_EXT=-server -Xms128m -Xmx128m -Xmn128m" \
-e "JAVA_OPTS=-Duser.home=/opt" \
-v /data/rocketmq/rmqserver/logs:/opt/logs \
-v /data/rocketmq/rmqserver/store:/opt/store \
foxiswho/rocketmq:server-4.5.1
创建broker容器
docker create -p 10911:10911 -p 10909:10909 --name rmqbroker \
-e "JAVA_OPTS=-Duser.home=/opt" \
-e "JAVA_OPT_EXT=-server -Xms128m -Xmx128m -Xmn128m" \
-v /data/rocketmq/rmqbroker/conf/broker.conf:/etc/rocketmq/broker.conf \
-v /data/rocketmq/rmqbroker/logs:/opt/logs \
-v /data/rocketmq/rmqbroker/store:/opt/store \
foxiswho/rocketmq:broker-4.5.1
/data/rocketmq/rmqbroker/conf/broker.conf如下:
# 所属集群名字
brokerClusterName = DefaultCluster
# broker 名字,注意此处不同的配置文件填写的不一样,如果在 broker-a.properties 使用: broker-a,
# 在 broker-b.properties 使用: broker-b
brokerName = broker-a
# 0 表示 Master,> 0 表示 Slave
brokerId = 0
#启动IP
brokerIP1=192.168.56.100
# nameServer地址,分号分割
namesrvAddr=192.168.56.100:9876
# 在发送消息时,自动创建服务器不存在的topic,默认创建的队列数
defaultTopicQueueNums=4
# 是否允许 Broker 自动创建 Topic,建议线下开启,线上关闭 !!!
autoCreateTopicEnable=true
# 是否允许 Broker 自动创建订阅组,建议线下开启,线上关闭
autoCreateSubscriptionGroup=true
# 开启过滤
enablePropertyFilter = true
# 删除文件时间点,默认凌晨4点
deleteWhen = 04
# 文件保留时间,默认48小时
fileReservedTime = 48
# commitLog 每个文件的大小默认1G
mapedFileSizeCommitLog=1073741824
# ConsumeQueue 每个文件默认存 30W 条,根据业务情况调整
mapedFileSizeConsumeQueue=300000
# destroyMapedFileIntervalForcibly=120000
# redeleteHangedFileInterval=120000
# 检测物理文件磁盘空间
diskMaxUsedSpaceRatio=88
# 限制的消息大小
maxMessageSize=65536
# Broker 的角色
# - ASYNC_MASTER 异步复制Master
# - SYNC_MASTER 同步双写Master
# - SLAVE
brokerRole = ASYNC_MASTER
# 刷盘方式
# - ASYNC_FLUSH 异步刷盘
# - SYNC_FLUSH 同步刷盘
flushDiskType = ASYNC_FLUSH
# 发消息线程池数量
# sendMessageThreadPoolNums=128
# 拉消息线程池数量
# pullMessageThreadPoolNums=128
启动容器
docker start rmqserver rmqbroker
停止删除容器
docker rm -f rmqbroker rmqserver
RocketMQ的管理工具
docker pull styletang/rocketmq-console-ng:latest
创建并启动容器
docker run -d --name rmqconsole -e "JAVA_OPTS=-Drocketmq.namesrv.addr=192.168.56.100:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false" -p 8082:8080 -t styletang/rocketmq-console-ng:latest
通过浏览器进行访问:http://192.168.56.100:8082/#/
docker-compose安装
docker-compose.yml:
version: '3.5'
services:
rmqnamesrv:
image: foxiswho/rocketmq:server
container_name: rmqnamesrv
ports:
- 9876:9876
volumes:
- /data/rocketmq/rmqserver/logs:/opt/logs
- /data/rocketmq/rmqserver/store:/opt/store
environment:
JAVA_OPTS: " -Duser.home=/opt"
JAVA_OPT_EXT: "-server -Xms128m -Xmx128m -Xmn128m"
networks:
rmq:
aliases:
- rmqnamesrv
rmqbroker:
image: foxiswho/rocketmq:broker
container_name: rmqbroker
ports:
- 10909:10909
- 10911:10911
volumes:
- /data/rocketmq/rmqbroker/logs:/opt/logs
- /data/rocketmq/rmqbroker/store:/opt/store
- /data/rocketmq/rmqbroker/brokerconf/broker.conf:/etc/rocketmq/broker.conf
environment:
NAMESRV_ADDR: "rmqnamesrv:9876"
JAVA_OPTS: " -Duser.home=/opt"
JAVA_OPT_EXT: "-server -Xms128m -Xmx128m -Xmn128m"
command: mqbroker -c /etc/rocketmq/broker.conf
depends_on:
- rmqnamesrv
networks:
rmq:
aliases:
- rmqbroker
rmqconsole:
image: styletang/rocketmq-console-ng
container_name: rmqconsole
ports:
- 8082:8080
environment:
JAVA_OPTS: "-Drocketmq.namesrv.addr=rmqnamesrv:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false"
depends_on:
- rmqnamesrv
networks:
rmq:
aliases:
- rmqconsole
networks:
rmq:
name: rmq
driver: bridge