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

而不使用FileChannel.write()?rocketmq使用mmap文件写入,可能会导致使用

这是对FileChannel.write()和mmap文件写入的测试 https://github.com/jkreps/valencia/blob/master/src/test/java/valencia/TestLinearWritePerformance.java 更重要的是,MaxDirectMemorySize不适用于mmap文件占用的内存。

MaxDirectMemorySize不适用于mmap文件持有的内存。SHR内存等于mmap文件大小。

提问114.png

提问115.png

原提问者GitHub用户Ah39

展开
收起
芬奇福贵 2023-05-26 16:15:10 368 0
1 条回答
写回答
取消 提交回答
  • 与FileChannel相比,MMAP可以直接写入页面缓存,但带有directbuffer的FileChannel需要先写入内存,然后再写入页面缓存。因此,当将大量小数据写入文件时,MMAP具有优势。

    原回答者GitHub用户duhengforever

    2023-05-26 18:04:46
    赞同 展开评论 打赏
问答标签:
问答地址:
相关产品:

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

相关产品

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

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