window进行rocketMQ集群搭建–简单无错版

参考
参考1
参考2
参考3

官网下载这个

在这里插入图片描述

在这里插入图片描述
下载包rocketmq-all-5.0.0-ALPHA-bin-release

配置环境变量
此电脑-属性-高级系统设置-高级-环境变量-系统变量
在这里插入图片描述
新建系统变量
ROCKETMQ_HOME
D:\java\rocketmq-all-5.0.0-ALPHA-bin-release
在这里插入图片描述
新建系统变量
NAMESRV_ADDR
localhost:9876

解压目录–修改文件名
D:\rocketMq\rocketmq-5.0-one
在这里插入图片描述
没有store,后期会加

在这里插入图片描述
broker-a.properties 内容

#所属集群名字
brokerClusterName=ItcastCluster
#broker名字,名字可重复,为了管理,每个master起一个名字,他的slave同他,eg:Amaster叫broker-a,他的slave也叫broker-a
brokerName=broker-a
#0 表示 Master,>0 表示 Slave
brokerId=0
#删除文件时间点,默认凌晨 4点
deleteWhen=04
#文件保留时间,默认 48 小时
fileReservedTime=48

#nameServer地址,分号分割
namesrvAddr=127.0.0.1:9876;127.0.0.1:9877
#在发送消息时,自动创建服务器不存在的topic,默认创建的队列数
defaultTopicQueueNums=4

#brokerIP1 当前broker监听的IP
brokerIP1=127.0.0.1
#brokerIP2 存在broker主从时,在broker主节点上配置了brokerIP2的话,broker从节点会连接主节点配置的brokerIP2来同步
brokerIp2=127.0.01

#Broker 对外服务的监听端口
listenPort=10911
#是否允许 Broker 自动创建Topic,建议线下开启,线上关闭
autoCreateTopicEnable=true
#是否允许 Broker 自动创建订阅组,建议线下开启,线上关闭
autoCreateSubscriptionGroup=true

#commitLog每个文件的大小默认1G
mapedFileSizeCommitLog=1073741824
#ConsumeQueue每个文件默认存30W条,根据业务情况调整
mapedFileSizeConsumeQueue=300000
#destroyMapedFileIntervalForcibly=120000
#redeleteHangedFileInterval=120000
#检测物理文件磁盘空间
diskMaxUsedSpaceRatio=88


#存储路径
storePathRootDir=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-a
#commitLog 存储路径
storePathCommitLog=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-a\\commitlog
#消费队列存储路径存储路径
storePathConsumeQueue=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-a\\consumequeue
#消息索引存储路径
storePathIndex=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-a\\index
#checkpoint 文件存储路径
storeCheckpoint=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-a\\checkpoint
#abort 文件存储路径
abortFile=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-a\\abortfile

#限制的消息大小
maxMessageSize=65536
#flushCommitLogLeastPages=4
#flushConsumeQueueLeastPages=2
#flushCommitLogThoroughInterval=10000
#flushConsumeQueueThoroughInterval=60000
#Broker 的角色
#- ASYNC_MASTER 异步复制Master
#- SYNC_MASTER 同步双写Master
#- SLAVE
brokerRole=ASYNC_MASTER
#刷盘方式
#- ASYNC_FLUSH 异步刷盘
#- SYNC_FLUSH 同步刷盘
flushDiskType=ASYNC_FLUSH
#checkTransactionMessageEnable=false
#发消息线程池数量
#sendMessageThreadPoolNums=128
#拉消息线程池数量
#pullMessageThreadPoolNums=128

broker-a-s.properties 内容

#所属集群名字
brokerClusterName=ItcastCluster
#broker名字,名字可重复,为了管理,每个master起一个名字,他的slave同他,eg:Amaster叫broker-a,他的slave也叫broker-a
brokerName=broker-a-s
#0 表示 Master,>0 表示 Slave
brokerId=1
#删除文件时间点,默认凌晨 4点
deleteWhen=04
#文件保留时间,默认 48 小时
fileReservedTime=48

#nameServer地址,分号分割
namesrvAddr=127.0.0.1:9876;127.0.0.1:9877
#在发送消息时,自动创建服务器不存在的topic,默认创建的队列数
defaultTopicQueueNums=4

#brokerIP1 当前broker监听的IP
brokerIP1=127.0.0.1
#brokerIP2 存在broker主从时,在broker主节点上配置了brokerIP2的话,broker从节点会连接主节点配置的brokerIP2来同步
brokerIp2=127.0.01

#Broker 对外服务的监听端口
listenPort=10711
#是否允许 Broker 自动创建Topic,建议线下开启,线上关闭
autoCreateTopicEnable=true
#是否允许 Broker 自动创建订阅组,建议线下开启,线上关闭
autoCreateSubscriptionGroup=true

#commitLog每个文件的大小默认1G
mapedFileSizeCommitLog=1073741824
#ConsumeQueue每个文件默认存30W条,根据业务情况调整
mapedFileSizeConsumeQueue=300000
#destroyMapedFileIntervalForcibly=120000
#redeleteHangedFileInterval=120000
#检测物理文件磁盘空间
diskMaxUsedSpaceRatio=88


#存储路径
storePathRootDir=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-a-s
#commitLog 存储路径
storePathCommitLog=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-a-s\\commitlog
#消费队列存储路径存储路径
storePathConsumeQueue=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-a-s\\consumequeue
#消息索引存储路径
storePathIndex=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-a-s\\index
#checkpoint 文件存储路径
storeCheckpoint=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-a-s\\checkpoint
#abort 文件存储路径
abortFile=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-a-s\\abortfile

#限制的消息大小
maxMessageSize=65536
#flushCommitLogLeastPages=4
#flushConsumeQueueLeastPages=2
#flushCommitLogThoroughInterval=10000
#flushConsumeQueueThoroughInterval=60000
#Broker 的角色
#- ASYNC_MASTER 异步复制Master
#- SYNC_MASTER 同步双写Master
#- SLAVE
brokerRole=ASYNC_MASTER
#刷盘方式
#- ASYNC_FLUSH 异步刷盘
#- SYNC_FLUSH 同步刷盘
flushDiskType=ASYNC_FLUSH
#checkTransactionMessageEnable=false
#发消息线程池数量
#sendMessageThreadPoolNums=128
#拉消息线程池数量
#pullMessageThreadPoolNums=128

broker-b.properties 内容

#所属集群名字
brokerClusterName=ItcastCluster
#broker名字,名字可重复,为了管理,每个master起一个名字,他的slave同他,eg:Amaster叫broker-a,他的slave也叫broker-a
brokerName=broker-b
#0 表示 Master,>0 表示 Slave
brokerId=0
#删除文件时间点,默认凌晨 4点
deleteWhen=04
#文件保留时间,默认 48 小时
fileReservedTime=48

#nameServer地址,分号分割
namesrvAddr=127.0.0.1:9876;127.0.0.1:9877
#在发送消息时,自动创建服务器不存在的topic,默认创建的队列数
defaultTopicQueueNums=4

#brokerIP1 当前broker监听的IP
brokerIP1=127.0.0.1
#brokerIP2 存在broker主从时,在broker主节点上配置了brokerIP2的话,broker从节点会连接主节点配置的brokerIP2来同步
brokerIp2=127.0.01

#Broker 对外服务的监听端口
listenPort=10811
#是否允许 Broker 自动创建Topic,建议线下开启,线上关闭
autoCreateTopicEnable=true
#是否允许 Broker 自动创建订阅组,建议线下开启,线上关闭
autoCreateSubscriptionGroup=true

#commitLog每个文件的大小默认1G
mapedFileSizeCommitLog=1073741824
#ConsumeQueue每个文件默认存30W条,根据业务情况调整
mapedFileSizeConsumeQueue=300000
#destroyMapedFileIntervalForcibly=120000
#redeleteHangedFileInterval=120000
#检测物理文件磁盘空间
diskMaxUsedSpaceRatio=88


#存储路径
storePathRootDir=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-b
#commitLog 存储路径
storePathCommitLog=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-b\\commitlog
#消费队列存储路径存储路径
storePathConsumeQueue=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-b\\consumequeue
#消息索引存储路径
storePathIndex=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-b\\index
#checkpoint 文件存储路径
storeCheckpoint=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-b\\checkpoint
#abort 文件存储路径
abortFile=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-b\\abortfile

#限制的消息大小
maxMessageSize=65536
#flushCommitLogLeastPages=4
#flushConsumeQueueLeastPages=2
#flushCommitLogThoroughInterval=10000
#flushConsumeQueueThoroughInterval=60000
#Broker 的角色
#- ASYNC_MASTER 异步复制Master
#- SYNC_MASTER 同步双写Master
#- SLAVE
brokerRole=ASYNC_MASTER
#刷盘方式
#- ASYNC_FLUSH 异步刷盘
#- SYNC_FLUSH 同步刷盘
flushDiskType=ASYNC_FLUSH
#checkTransactionMessageEnable=false
#发消息线程池数量
#sendMessageThreadPoolNums=128
#拉消息线程池数量
#pullMessageThreadPoolNums=128

broker-b-s.properties 内容

#所属集群名字
brokerClusterName=ItcastCluster
#broker名字,名字可重复,为了管理,每个master起一个名字,他的slave同他,eg:Amaster叫broker-a,他的slave也叫broker-a
brokerName=broker-b-s
#0 表示 Master,>0 表示 Slave
brokerId=1
#删除文件时间点,默认凌晨 4点
deleteWhen=04
#文件保留时间,默认 48 小时
fileReservedTime=48

#nameServer地址,分号分割
namesrvAddr=127.0.0.1:9876;127.0.0.1:9877
#在发送消息时,自动创建服务器不存在的topic,默认创建的队列数
defaultTopicQueueNums=4

#brokerIP1 当前broker监听的IP
brokerIP1=127.0.0.1
#brokerIP2 存在broker主从时,在broker主节点上配置了brokerIP2的话,broker从节点会连接主节点配置的brokerIP2来同步
brokerIp2=127.0.01

#Broker 对外服务的监听端口
listenPort=10611
#是否允许 Broker 自动创建Topic,建议线下开启,线上关闭
autoCreateTopicEnable=true
#是否允许 Broker 自动创建订阅组,建议线下开启,线上关闭
autoCreateSubscriptionGroup=true

#commitLog每个文件的大小默认1G
mapedFileSizeCommitLog=1073741824
#ConsumeQueue每个文件默认存30W条,根据业务情况调整
mapedFileSizeConsumeQueue=300000
#destroyMapedFileIntervalForcibly=120000
#redeleteHangedFileInterval=120000
#检测物理文件磁盘空间
diskMaxUsedSpaceRatio=88


#存储路径
storePathRootDir=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-b-s
#commitLog 存储路径
storePathCommitLog=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-b-s\\commitlog
#消费队列存储路径存储路径
storePathConsumeQueue=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-b-s\\consumequeue
#消息索引存储路径
storePathIndex=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-b-s\\index
#checkpoint 文件存储路径
storeCheckpoint=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-b-s\\checkpoint
#abort 文件存储路径
abortFile=D:\\rocketMq\\rocketmq-5.0-one\\store\\broker-b-s\\abortfile

#限制的消息大小
maxMessageSize=65536
#flushCommitLogLeastPages=4
#flushConsumeQueueLeastPages=2
#flushCommitLogThoroughInterval=10000
#flushConsumeQueueThoroughInterval=60000
#Broker 的角色
#- ASYNC_MASTER 异步复制Master
#- SYNC_MASTER 同步双写Master
#- SLAVE
brokerRole=ASYNC_MASTER
#刷盘方式
#- ASYNC_FLUSH 异步刷盘
#- SYNC_FLUSH 同步刷盘
flushDiskType=ASYNC_FLUSH
#checkTransactionMessageEnable=false
#发消息线程池数量
#sendMessageThreadPoolNums=128
#拉消息线程池数量
#pullMessageThreadPoolNums=128

namesrv-a.properties 内容

listenPort=9876

namesrv-b.properties 内容

listenPort=9877

他们是改内存配置,其实电脑很好的话,不改也行
runserver.cmd
runserver.sh
runboker.cmd
runboker.sh
按这个配置就行了(如果要改)
Xms512m -Xmx512m -Xmn256m

启动(启动程序都在bin目录)
nameserver

第一个

mqnamesrv.cmd -c ../conf/2m-2s-sync/namesrv-a.properties

第二个

mqnamesrv.cmd -c ../conf/2m-2s-sync/namesrv-b.properties

broker
主a

mqbroker.cmd -c ../conf/2m-2s-sync/broker-a.properties

副a

mqbroker.cmd -c ../conf/2m-2s-sync/broker-a-s.properties

主b

mqbroker.cmd -c ../conf/2m-2s-sync/broker-b.properties

副b

mqbroker.cmd -c ../conf/2m-2s-sync/broker-b-s.properties

rokcetmq-console
官网找版本,有点难找,耐心一点
在这里插入图片描述

控制台(修改)
在这里插入图片描述
pom.xml添加JAXB依赖
D:\java\rocketmq-externals-release-rocketmq-console-1.0.0\rocketmq-console
idea导入找不到,我也不知道为什么,直接拖动修改吧

        <!-- https://mvnrepository.com/artifact/javax.xml.bind/jaxb-api -->
        <dependency>
            <groupId>javax.xml.bind</groupId>
            <artifactId>jaxb-api</artifactId>
            <version>2.3.0</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/com.sun.xml.bind/jaxb-impl -->
        <dependency>
            <groupId>com.sun.xml.bind</groupId>
            <artifactId>jaxb-impl</artifactId>
            <version>2.3.0</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/com.sun.xml.bind/jaxb-core -->
        <dependency>
            <groupId>com.sun.xml.bind</groupId>
            <artifactId>jaxb-core</artifactId>
            <version>2.3.0</version>
        </dependency>
        <!-- https://mvnrepository.com/artifact/javax.activation/activation -->
        <dependency>
            <groupId>javax.activation</groupId>
            <artifactId>activation</artifactId>
            <version>1.1.1</version>
        </dependency>

项目下cmd
打包

mvn clean install package -Dmaven.test.skip=true

rocketmq-console-ng-1.0.0.jar 是包名
在这里插入图片描述
cmd(项目的target包下)
运行

java -jar rocketmq-console-ng-1.0.0.jar

可以自己修改名字


版权声明:本文为weixin_45309354原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。