V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
Eridani117
V2EX  ›  问与答

Redis 持久化时的内存问题

  •  
  •   Eridani117 · Mar 30, 2021 · 1205 views
    This topic created in 1854 days ago, the information mentioned may be changed or developed.

    前几天一个前辈说,Redis 在 Rdb 持久化的时候,应该拥有双倍内存。
    比如 MaxMemory 是 1G,那么机器总内存就应有 2G 。
    我觉得他讲的应该是 fork 出子线程之后,子线程将主线程的内存做一个快照,导致总共需要 2G 。
    但是 Linux 不是有 copy-on-write 机制吗,只有内存页被修改主线程才需要新建一个页副本,其他情况下子线程和父线程共享内存。
    只有极端情况下才会导致需要双倍内存。
    请问有人能详细解释一下吗。

    1 replies    2021-03-30 16:34:55 +08:00
    wakzz
        1
    wakzz  
       Mar 30, 2021
    这里说的就是 COW 过程中,原内存的一个内存页(默认 4K)被修改后,会发生中断然后复制出这个内存页的副本。极端情况下,如果 COW 过程中每个内存页都被修改,那么就会出现内存翻倍的情况。
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   4693 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 42ms · UTC 01:03 · PVG 09:03 · LAX 18:03 · JFK 21:03
    ♥ Do have faith in what you're doing.