共享内存中的Shared_dirty vs Private_dirty

Vik*_*kas 6 linux operating-system memory-management shared-memory linux-kernel

我有使用共享内存的多进程应用程序.我试图在我的应用程序中检测内存泄漏.我在/ proc/$ pid/smap中找到了这个

 2b51cd2b2000-2b53b8aa4000 rw-s 00000000 00:09 17151225                   /dev/zero (deleted)
  Size:           8052680 kB
  Rss:              31608 kB
  Shared_Clean:      1524 kB
  Shared_Dirty:     25736 kB
  Private_Clean:        0 kB
  Private_Dirty:     4348 kB
  Swap:                 0 kB
  Pss:               6945 kB
Run Code Online (Sandbox Code Playgroud)

这是我分配的共享内存.(大小告诉我这是我用mmap分配的内存)

我试图了解内存本身共享的上下文中共享/私有之间的区别.看's'标志.

如果任何人可以在共享内存的上下文中解释Shared_Clean与Private_Clean Shared_Dirty vs Private_Dirty之间的区别.

caf*_*caf 12

Clean和Dirty之间的区别是指自从写入内存以来页面是否已写出到后备存储.对于映射/dev/zero,页面显然从不写出,因此只读取了干净页面,而写入了脏页面.

对于共享映射,Private和Shared之间的区别在于页面是否仅由您正在检查的进程引用,或者它们是否已被多个进程引用.

总结如下:

  • Shared_Clean 是映射中已被此进程引用的页面,以及至少一个其他进程,但不是由任何进程编写的;
  • Shared_Dirty 是映射中的页面,该页面已被此进程和至少一个其他进程引用,并由至少一个进程编写;
  • Private_Clean 映射中的页面是否已被读取但未由此进程写入但未被任何其他进程引用;
  • Private_Dirty 是映射中由此进程写入但未被任何其他进程引用的页面.

页面可以在写入时从"清理"移动到"脏",在另一个进程引用它们时从"私有"移动到"共享".

如果映射真实的磁盘文件,那么当内核写出页面时,页面也可以从Dirty转移到Clean.