RocketMQ中的消息存储在Broker节点的文件系统中,默认情况下,存储目录位于Broker节点的store
目录下。具体路径可以在broker.properties
配置文件中的storePathRootDir
参数中设置,默认为${user.home}/store
。
在RocketMQ中,消息的存储位置取决于您选择的存储模式。RocketMQ支持两种消息存储模式:持久化存储和内存存储。
持久化存储:
当使用持久化存储模式时,消息会被写入磁盘,并存储在指定的存储路径下。默认情况下,存储路径为$HOME/store
(也可以通过配置文件进行修改)。
在存储路径下,RocketMQ将根据一些规则和目录结构来组织消息存储文件。其中,消息数据文件(commitlog)存储在$HOME/store/commitlog
目录下,而消费进度文件(consumequeue)存储在$HOME/store/consumequeue
目录下。
内存存储:
当使用内存存储模式时,消息将存储在内存中,不会写入磁盘。这种模式主要用于开发、测试和调试等临时环境,不适合生产环境使用。
存储路径的具体位置可以通过修改RocketMQ的配置文件(broker.conf)中的相关参数进行配置。您可以在配置文件中搜索以下参数,以找到和设置存储路径相关的配置项:
storePathRootDir
:指定存储路径的根目录。storePathCommitLog
:指定消息数据文件(commitlog)的存储路径。storePathConsumeQueue
:指定消费进度文件(consumequeue)的存储路径。一般默认是~/store/commitlog,这个结构树我们补一个文档进去晚点。过期是按照commitLog来的, 不区分消费与否,此回答整理自钉群“群2-Apache RocketMQ 中国开发者钉钉群”
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
阿里云拥有国内全面的云原生产品技术以及大规模的云原生应用实践,通过全面容器化、核心技术互联网化、应用 Serverless 化三大范式,助力制造业企业高效上云,实现系统稳定、应用敏捷智能。拥抱云原生,让创新无处不在。