RocketMQ 开源项目安装与使用指南
2024-08-07 11:09:10作者:伍霜盼Ellen
目录结构及介绍
当你成功克隆了 RocketMQ 的仓库后, 你会看到如下目录结构:
├── bin # 包含一些用于操作 Broker 和 NameServer 的 shell 脚本, 如: mqadmin, tools.sh等
│ ├── mqadmin # 用于管理RocketMQ,如查询消息消费情况,向指定topic发送消息等功能
│ └── tools.sh # 提供了一系列的工具命令,如数据导出,性能测试等
└── conf # 存放RocketMQ相关配置文件的目录
├── broker.conf # Broker 配置文件, 决定Broker如何运行(例如监听端口,队列数量)
└── namesrv.conf # Name Server 配置文件, 它决定了Name Server的基本行为(例如监听端口,日志存储位置)
在根目录下还有其他的重要组成部分:
LICENSE
: Apache License Version 2.0 授权许可说明。NOTICE
: 文件中记录了对RocketMQ有贡献的人或组织。
启动文件介绍
Broker启动脚本
Broker 是 RocketMQ 中的数据处理节点,它负责接收和存储来自生产者的消息以及将消息推送给消费者进行消费。要启动一个Broker实例,你需要执行以下步骤:
- 首先修改
conf/broker.conf
中的参数来适配你的环境,比如设置broker IP(brokerIP1
),broker name(brokerName
),存储路径(storePathRootDir
)等。 - 使用
bin/start-broker.sh
(Linux/Mac)或bin\start-broker.cmd
(Windows)命令来启动Broker服务。如果想要以守护进程的方式运行,则可以添加-c conf/broker.conf
参数指向配置文件。
NameServer启动脚本
NameServer 是 RocketMQ 系统的核心组件之一,主要功能是提供对Broker地址的管理和发现机制。要启动NameServer,你可以执行以下指令:
- 修改
conf/namesrv.conf
文件,以便正确设定NameServer的监听端口和其他参数。 - 执行
bin/start-namesrv.sh
(Linux/Mac)或bin\start-namesrv.cmd
(Windows)。你同样可以通过加入-c conf/namesrv.conf
来明确指定配置文件的位置。
此外,在bin
目录下还有一个mqadmin
工具,提供了丰富的操作,如查询、控制Broker和NameServer状态、检查主题和队列的状态等。
配置文件介绍
NameServer配置文件 (namesrv.conf
)
listenPort
: 指定NameServer监听的端口号,默认为9876
。mixAll=false
: 这个选项通常设置为false
,表示NameServer不参与混杂模式下的数据传输。logApp=namesrv
: 日志前缀,用于区分不同类型的日志文件。
Broker配置文件 (broker.conf
)
brokerID=-1
: 根据集群类型来决定,对于主备集群,需要给Master和Slave分配不同的ID。brokerRole=SINGLE_BROKER
: 表示Broker的角色,可以选择SINGLE_BROKER
,MASTER
或者SLAVE
。brokerIP1=
: 设置Broker的IP地址。storePathRootDir=
: 消息的存储路径,必须存在且具备读写权限。flushDiskType=ASYNC_FLUSH
: 控制数据持久化的策略,包括同步(SYNC_FLUSH)和异步(ASYNC_FLUSH)两种方式。
请注意,启动任何服务前都要确保已正确配置相关的配置项,否则可能会导致服务无法正常工作。
热门项目推荐
相关项目推荐
鸿蒙开发工具大赶集
本仓将收集和展示鸿蒙开发工具,欢迎大家踊跃投稿。通过pr附上您的工具介绍和使用指南,并加上工具对应的链接,通过的工具将会成功上架到我们社区。013hertz
Go 微服务 HTTP 框架,具有高易用性、高性能、高扩展性等特点。Go01每日精选项目
🔥🔥 每日精选已经升级为:【行业动态】,快去首页看看吧,后续都在【首页 - 行业动态】内更新,多条更新哦~🔥🔥 每日推荐行业内最新、增长最快的项目,快速了解行业最新热门项目动态~~029kitex
Go 微服务 RPC 框架,具有高性能、强可扩展的特点。Go00Cangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。Cangjie060毕方Talon工具
本工具是一个端到端的工具,用于项目的生成IR并自动进行缺陷检测。Python040PDFMathTranslate
PDF scientific paper translation with preserved formats - 基于 AI 完整保留排版的 PDF 文档全文双语翻译,支持 Google/DeepL/Ollama/OpenAI 等服务,提供 CLI/GUI/DockerPython06mybatis-plus
mybatis 增强工具包,简化 CRUD 操作。 文档 http://baomidou.com 低代码组件库 http://aizuda.comJava03国产编程语言蓝皮书
《国产编程语言蓝皮书》-编委会工作区018- DDeepSeek-R1探索新一代推理模型,DeepSeek-R1系列以大规模强化学习为基础,实现自主推理,表现卓越,推理行为强大且独特。开源共享,助力研究社区深入探索LLM推理能力,推动行业发展。【此简介由AI生成】。Python00
热门内容推荐
最新内容推荐
项目优选
收起

前端智能化场景解决方案UI库,轻松构建你的AI应用,我们将持续完善更新,欢迎你的使用与建议。
官网地址:https://matechat.gitcode.com
414
36

Python - 100天从新手到大师
Python
612
115

本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
205
60
Ffit-framework
FIT: 企业级AI开发框架,提供多语言函数引擎(FIT)、流式编排引擎(WaterFlow)及Java生态的LangChain替代方案(FEL)。原生/Spring双模运行,支持插件热插拔与智能聚散部署,无缝统一大模型与业务系统。
Java
113
13

🎉 基于Spring Boot、Spring Cloud & Alibaba、Vue3 & Vite、Element Plus的分布式前后端分离微服务架构权限管理系统
Vue
45
29

a fast,lightweight and joy web framework
Cangjie
11
2

本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
286
80

Go 微服务 HTTP 框架,具有高易用性、高性能、高扩展性等特点。
Go
7
1

旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
60
48

open-eBackup是一款开源备份软件,采用集群高扩展架构,通过应用备份通用框架、并行备份等技术,为主流数据库、虚拟化、文件系统、大数据等应用提供E2E的数据备份、恢复等能力,帮助用户实现关键数据高效保护。
HTML
90
65