开发者社区 > 云原生 > 正文

请问rocketmq中消息存储在哪个目录下?

请问rocketmq中消息存储在哪个目录下?

展开
收起
提个问题! 2023-07-10 18:12:58 3167 0
3 条回答
写回答
取消 提交回答
  • 十分耕耘,一定会有一分收获!

    RocketMQ中的消息存储在Broker节点的文件系统中,默认情况下,存储目录位于Broker节点的store目录下。具体路径可以在broker.properties配置文件中的storePathRootDir参数中设置,默认为${user.home}/store

    2023-07-11 08:41:31
    赞同 展开评论 打赏
  • 在RocketMQ中,消息的存储位置取决于您选择的存储模式。RocketMQ支持两种消息存储模式:持久化存储和内存存储。

    1. 持久化存储:
      当使用持久化存储模式时,消息会被写入磁盘,并存储在指定的存储路径下。默认情况下,存储路径为$HOME/store(也可以通过配置文件进行修改)。

      在存储路径下,RocketMQ将根据一些规则和目录结构来组织消息存储文件。其中,消息数据文件(commitlog)存储在$HOME/store/commitlog目录下,而消费进度文件(consumequeue)存储在$HOME/store/consumequeue目录下。

    2. 内存存储:
      当使用内存存储模式时,消息将存储在内存中,不会写入磁盘。这种模式主要用于开发、测试和调试等临时环境,不适合生产环境使用。

    存储路径的具体位置可以通过修改RocketMQ的配置文件(broker.conf)中的相关参数进行配置。您可以在配置文件中搜索以下参数,以找到和设置存储路径相关的配置项:

    • storePathRootDir:指定存储路径的根目录。
    • storePathCommitLog:指定消息数据文件(commitlog)的存储路径。
    • storePathConsumeQueue:指定消费进度文件(consumequeue)的存储路径。
    2023-07-10 19:18:35
    赞同 展开评论 打赏
  • 一般默认是~/store/commitlog,这个结构树我们补一个文档进去晚点。过期是按照commitLog来的, 不区分消费与否,此回答整理自钉群“群2-Apache RocketMQ 中国开发者钉钉群”

    2023-07-10 18:15:00
    赞同 展开评论 打赏

阿里云拥有国内全面的云原生产品技术以及大规模的云原生应用实践,通过全面容器化、核心技术互联网化、应用 Serverless 化三大范式,助力制造业企业高效上云,实现系统稳定、应用敏捷智能。拥抱云原生,让创新无处不在。

相关产品

  • 云消息队列 MQ
  • 相关电子书

    更多
    RocketMQ Client-GO 介绍 立即下载
    RocketMQ Prometheus Exporter 打造定制化 DevOps 平台 立即下载
    基于 RocketMQ Prometheus Exporter 打造定制化 DevOps 平台 立即下载