操作系统不会自动把映射的页扔掉。
你这个做法没有任何的优化啊,用过的内存超过物理+swap就会被oom kill
你还不如创建一个32GB的kv数据库呢,让数据库自己管缓存。
【 在 hgoldfish 的大作中提到: 】
: 标 题: 能用 mmap 来省点内存吗?
: 发信站: 水木社区 (Sun Aug 14 21:03:34 2022), 站内
:
: 我有个程序往内存里面加载了大量的数据 (8G+),以供外部服务器使用。
:
: 每一段数据都有差不多的概率被访问到。访问的频率中等,不是特别热的数据。既有读取与有写入,但写入相对比较少。
:
: 如果每次都从文件中加载的话,反序列化很占用 CPU 时间。放在内存里面又太占用 VPS 内存,云服务器的内存很贵。
:
: 是不是可以用 mmap 优化一下?我创建一个 32G 大小的文件,然后用 mmap() 映射到内存里面,把这些数据放在映射内存里面?
:
: 这样做的话,操作系统会在物理内存不足的时候自动地把映射的页扔掉吧?等需要读取到的时候再重新从磁盘加载?减少 OOM 的机会?
:
: --
: 灭绝人性啊
:
:
: ※ 来源:·水木社区 mysmth.net·[FROM: 117.24.95.*]
--
FROM 124.126.151.*