如果文件非常大,远大于内存,这样的随机read,如果时间长了导致物理页分配太多,是会让Linux做swap的,这会大幅影响性能吧,Havenask如果出现这种情况怎么办?
当使用 mmap 而不加 mlock 时(即 "mmap 非 lock"),映射的内存区域不会被锁定在物理内存中,这意味着如果系统内存不足,这部分内存可能会被交换出去(swap out),这会导致性能下降,因为访问交换出去的数据需要磁盘 I/O 操作。
如果文件非常大,远大于可用的物理内存,并且使用非锁定的 mmap,确实可能会因为频繁的缺页异常(page fault)和可能的交换操作导致性能问题。
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。