rocketmq集群安装

本文详细介绍了RocketMQ消息中间件的单机版安装步骤与主从配置流程,包括下载安装、配置文件修改、日志存储设置、启动与停止服务,以及主从复制配置的具体操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.Rocketmq组成

Rocketmq由四部分组成

  1. producer 消息的生产者
  2. Consumer 消息的消费者
  3. Broker 消息的储存者
  4. NameServer 注册中心

RocketMQ的启动顺序是先启动NameServer,再启动Broker,这个时候消息队列就已经可以提供服务了

2.单机版安装

  1. 到官网上下载安装包,并解压到本地,我使用的版本是4.3.0

    # wget http://mirrors.tuna.tsinghua.edu.cn/apache/rocketmq/4.3.0/rocketmq-all-4.3.0-bin-release.zip
    # unzip rocketmq-all-4.3.0-bin-release.zip 
    # mv rocketmq-all-4.3.0-bin-release.zip /usr/local/rocketmq
    复制代码
  2. 创建日志存储文件夹

    # mkdir /usr/local/rocketmq/store
    # mkdir /usr/local/rocketmq/store/commit
    # mkdir /usr/local/rocketmq/store/consum
    # mkdir /usr/local/rocketmq/store/index
    复制代码
  3. rocket 配置文件修改

    # vim /usr/local/rocketmq/conf/2m-2s-async/broker-a.properties
    #可以直接将以下内容覆盖到properties文件中
    
    terName=rocketmq-cluster
    #broker 名字,注意此处不同的配置文件填写的不一样
    brokerName=broker-a
    #0 表示 Master, #0 表示 Slave
    brokerId=0
    #nameServer 地址,如果是集群使用,分号分割
    #假如我这台机器的地址是192.168.99.171
    namesrvAddr=192.168.99.171:9876
    #在发送消息时,自动创建服务器不存在的 topic,默认创建的队列数
    defaultTopicQueueNums=4
    #是否允许 Broker 自动创建 Topic,建议线下开启,线上关闭
    autoCreateTopicEnable=true
    #是否允许 Broker 自动创建订阅组,建议线下开启,线上关闭
    autoCreateSubscriptionGroup=true
    #Broker 对外服务的监听端口
    listenPort=10911
    #删除文件时间点,默认凌晨 4 点
    deleteWhen=04
    #文件保留时间,默认 48 小时
    fileReservedTime=120
    #commitLog 每个文件的大小默认 1G
    mapedFileSizeCommitLog=1073741824
    #ConsumeQueue 每个文件默认存 30W 条,根据业务情况调整
    mapedFileSizeConsumeQueue=300000
    #destroyMapedFileIntervalForcibly=120000
    #redeleteHangedFileInterval=120000
    #检测物理文件磁盘空间
    diskMaxUsedSpaceRatio=88
    #存储路径
    storePathRootDir=/usr/local/rocketmq/store
    #commitLog 存储路径
    storePathCommitLog=/usr/local/rocketmq/store/commitlog
    #消费队列存储路径存储路径
    storePathConsumeQueue=/usr/local/rocketmq/store/consumequeue
    #消息索引存储路径
    storePathIndex=/usr/local/rocketmq/store/index
    #checkpoint 文件存储路径
    storeCheckpoint=/usr/local/rocketmq/store/checkpoint
    #abort 文件存储路径
    abortFile=/usr/local/rocketmq/store/abort
    #限制的消息大小
    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
    复制代码
  4. 修改启动脚本参数 (默认会占用8G内存)

    # vim /usr/local/rocketmq/bin/runbroker.sh
    JAVA_OPT="${JAVA_OPT} -server -Xms1g -Xmx1g -Xmn512m -XX:PermSize=128m -
    XX:MaxPermSize=320m
    
    # vim /usr/local/rocketmq/bin/runserver.sh
    JAVA_OPT="${JAVA_OPT} -server -Xms1g -Xmx1g -Xmn512m -XX:PermSize=128m -
    XX:MaxPermSize=320m"
    复制代码
  5. 启动NameServer

    # cd /usr/local/rocketmq/bin
    # nohup sh mqnamesrv &
    复制代码
  6. 启动BrokerServer

    # cd /usr/local/rocketmq/bin
    # nohup sh mqbroker -c /usr/local/rocketmq/conf/2m-2s-async/broker-a.properties >>
    # /dev/null 2#&1 &
    复制代码
  7. 查看是否安装成功

    # jps
    4370 BrokerStartup
    4319 NamesrvStartup
    4847 Jps
    复制代码
  8. 停止服务

    # cd /usr/local/rocketmq/bin
    # sh mqshutdown broker
    # sh mqshutdown namesrv
    复制代码

3.主从配置

假设目前有192.169.99.171192.169.99.172两台机器,且已经各自安装好的rocketmq环境了,

在配置前,必须先停掉rocketmq服务

1.配置主服务器(假如192.168.99.171为主节点,192.168.99.172为从节点)

# cd /usr/local/rocketmq/conf/2m-2s-async
# vim broker-a.properties
#broker 名字,注意此处不同的配置文件填写的不一样
brokerName=broker-a
#0 表示 Master, >0 表示 Slave
brokerId=0
#nameServer地址,分号分割
namesrvAddr=192.168.99.171:9876;192.168.99.172:9876
#Broker 的角色
#- ASYNC_MASTER 异步复制 Master
#- SYNC_MASTER 同步双写 Master
#- SLAVE
brokerRole=ASYNC_MASTER
复制代码

2.配置从服务器

# cd /usr/local/rocketmq/conf/2m-2s-async
# vim broker-a-s.properties
#broker 名字,这里的名字必须和主服务的保持一致,这样才能确定对应的主节点
brokerName=broker-a
#0 表示 Master, >0 表示 Slave
brokerId=1
#nameServer地址,分号分割
namesrvAddr=192.168.99.171:9876;192.168.99.172:9876
#Broker 的角色
#- ASYNC_MASTER 异步复制 Master
#- SYNC_MASTER 同步双写 Master
#- SLAVE
brokerRole=SLAVE
复制代码

3.启动主服务器

##启动mqnameserv
# cd /usr/local/rocketmq/bin
# nohup sh mqnamesrv &	
##启动broker
# nohup sh mqbroker -c /usr/local/rocketmq/conf/2m-2s-async/broker-a.properties
复制代码

4.启动从服务器

##启动mqnameserv
# cd /usr/local/rocketmq/bin
# nohup sh mqnamesrv &	
##启动broker
# nohup sh mqbroker -c /usr/local/rocketmq/conf/2m-2s-async/broker-a-s.properties
复制代码

rocketmq的主从复制配置很简单,rocketmqconf文件夹下,根据不同的复制方式,创建了不同的文件,比如

2m-2s-async 双主双从 异步复制

2m-2s-sync 双主双从 同步复制

2m-noslave 双主模式

其中每个文件下的properties文件又是根据主配置和从配置划分的,比如2m-2s-async文件夹下

broker-a.properties表示第一台主节点的配置

broker-a-s.properties表示第一台从节点的配置

broker-b.properties表示第二台主节点的配置

broker-b-s.properties表示第二台从节点的配置

这些properties文件的指定方式并不是强制的,只是一种约定而已,然后启动broker传入对应的配置即可

也就是说你想让你某台机器启动是时候是主节点,那么就传入主节点的配置,反之也是一样

# nohup sh mqbroker -c 配置文件路径
复制代码

转载于:https://juejin.im/post/5c839c2ce51d453a122232ad

### 腾讯iOA私有化部署成本分析 腾讯iOA作为国内领先的零信任安全解决方案之一,支持SaaS、私有化及混合部署模式。在企业对数据安全性要求较高的场景下,私有化部署成为首选方案。以下从硬件投入、软件授权、运维服务等方面进行综合成本分析。 #### 硬件投入成本 私有化部署需要本地服务器资源来承载控制中心、网关和终端管理模块。根据典型中型企业需求,建议采用双节点高可用架构,每台服务器配置不低于8核CPU、32GB内存、1TB SSD存储空间,以保障策略计算、身份认证与访问控制的稳定运行[^2]。若采用物理服务器采购方式,两台设备成本约在10~15万元区间;若已有虚拟化平台,则可通过分配资源池降低硬件支[^1]。 #### 软件授权与服务费用 腾讯iOA私有化版本按用户数或终端数量进行授权计费,具体价格因功能模块组合而异。基础版包含零信任SDP(软件定义边界)与CWPP(云工作负载保护平台)能力,适用于远程办公与应用访问控制场景,年费约为每位用户300元起[^2]。对于500人规模的企业,年度授权成本约15万元。此外,首次部署需支付一次性实施服务费,涵盖系统集成、策略配置与接口对接等,通常为5~8万元[^3]。 #### 运维与扩展成本 私有化部署后需配备专业IT团队负责日常维护、日志审计与策略优化。若企业内部缺乏相应技术储备,可选择厂商提供的年度运维服务包,费用约为软件授权金额的20%~30%。随着业务增长,新增用户或功能模块扩展将产生额外成本,例如增加DLP(数据防泄漏)模块后,整体预算需上浮10%~15%。 #### 总体预算估算 综合上述因素,一个中型企业在完成腾讯iOA私有化部署后的首年总成本包括: - 硬件投入:10~15万元 - 软件授权:15万元(500用户规模) - 实施服务费:5~8万元 - 年度运维服务费:3~5万元 总计约33~41万元,略超30万元预算上限。若希望压缩至30万元以内,可通过精简功能模块(如仅启用SDP与基础身份认证)、复用现有服务器资源或延长付款周期等方式实现初步部署[^3]。 ```python # 成本估算示例代码 def estimate_cost(users=500, license_per_user=300, setup_fee=60000, maintenance_rate=0.25): hardware_cost = 120000 # 假设复用部分资源,取中间值 license_cost = users * license_per_user total_initial_cost = hardware_cost + license_cost + setup_fee annual_maintenance = (license_cost + setup_fee) * maintenance_rate total_first_year = total_initial_cost + annual_maintenance return { "Initial Hardware Cost": hardware_cost, "License Cost": license_cost, "Setup Service Fee": setup_fee, "Annual Maintenance": annual_maintenance, "Total First Year": total_first_year } estimate_cost() ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值