安装包安装
下载:
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.shJAVA_OPT="${JAVA_OPT} -server -Xms128m -Xmx128m -Xmn128m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=128m"vim runbroker.shJAVA_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.100namesrvAddr=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:9876cd binsh 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.1docker 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-bbrokerName = broker-a# 0 表示 Master,> 0 表示 SlavebrokerId = 0#启动IPbrokerIP1=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 每个文件的大小默认1GmapedFileSizeCommitLog=1073741824# ConsumeQueue 每个文件默认存 30W 条,根据业务情况调整mapedFileSizeConsumeQueue=300000# destroyMapedFileIntervalForcibly=120000# redeleteHangedFileInterval=120000# 检测物理文件磁盘空间diskMaxUsedSpaceRatio=88# 限制的消息大小maxMessageSize=65536# Broker 的角色# - ASYNC_MASTER 异步复制Master# - SYNC_MASTER 同步双写Master# - SLAVEbrokerRole = 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:servercontainer_name: rmqnamesrvports:- 9876:9876volumes:- /data/rocketmq/rmqserver/logs:/opt/logs- /data/rocketmq/rmqserver/store:/opt/storeenvironment:JAVA_OPTS: " -Duser.home=/opt"JAVA_OPT_EXT: "-server -Xms128m -Xmx128m -Xmn128m"networks:rmq:aliases:- rmqnamesrvrmqbroker:image: foxiswho/rocketmq:brokercontainer_name: rmqbrokerports:- 10909:10909- 10911:10911volumes:- /data/rocketmq/rmqbroker/logs:/opt/logs- /data/rocketmq/rmqbroker/store:/opt/store- /data/rocketmq/rmqbroker/brokerconf/broker.conf:/etc/rocketmq/broker.confenvironment:NAMESRV_ADDR: "rmqnamesrv:9876"JAVA_OPTS: " -Duser.home=/opt"JAVA_OPT_EXT: "-server -Xms128m -Xmx128m -Xmn128m"command: mqbroker -c /etc/rocketmq/broker.confdepends_on:- rmqnamesrvnetworks:rmq:aliases:- rmqbrokerrmqconsole:image: styletang/rocketmq-console-ngcontainer_name: rmqconsoleports:- 8082:8080environment:JAVA_OPTS: "-Drocketmq.namesrv.addr=rmqnamesrv:9876 -Dcom.rocketmq.sendMessageWithVIPChannel=false"depends_on:- rmqnamesrvnetworks:rmq:aliases:- rmqconsolenetworks:rmq:name: rmqdriver: bridge
