すべてのsystemd-sliceメンバーのメモリ使用量の合計がスライス自体のメモリ使用量と同じではないのはなぜですか?

すべてのsystemd-sliceメンバーのメモリ使用量の合計がスライス自体のメモリ使用量と同じではないのはなぜですか?

コンテキスト:

uname -srvmpio
Linux 3.10.0-1062.1.1.el7.x86_64 #1 SMP Fri Sep 13 22:55:44 UTC 2019 x86_64 x86_64 x86_64 GNU/Linux

cat /etc/redhat-release 
CentOS Linux release 7.7.1908 (Core)

systemctl --version
systemd 219
+PAM +AUDIT +SELINUX +IMA -APPARMOR +SMACK +SYSVINIT +UTMP +LIBCRYPTSETUP +GCRYPT +GNUTLS +ACL +XZ +LZ4 -SECCOMP +BLKID +ELFUTILS +KMOD +IDN

次のスライスがあります。

systemctl cat system-mystuff.slice
# /etc/systemd/system/system-mystuff.slice
[Unit]
Description=mystuff resources slice
DefaultDependencies=no
Before=slices.target

[Slice]
MemoryAccounting=yes
MemoryMax=4G
MemoryHigh=3.75G

スライスのメンバーはMemoryAccounting=yes.serviceファイルにもあります。

私が走るとき

systemd-cgtop -n1 -b -m | grep system-mystuff

次の出力が表示されます。

/system.slice/system-mystuff.slice                                            -      -     2.3G        -        -
/system.slice/system-mystuff.slice/[email protected]                    1      -   246.6M        -        -
/system.slice/system-mystuff.slice/process2.service                           1      -    82.7M        -        -
/system.slice/system-mystuff.slice/[email protected]                    1      -    49.5M        -        -
/system.slice/system-mystuff.slice/process4.service                           2      -     8.6M        -        -
/system.slice/system-mystuff.slice/process5.service                           1      -     8.4M        -        -
/system.slice/system-mystuff.slice/process6.service                           3      -     8.2M        -        -
/system.slice/system-mystuff.slice/process7.service                           1      -     7.3M        -        -
/system.slice/system-mystuff.slice/[email protected]                   1      -     6.1M        -        -
/system.slice/system-mystuff.slice/process9.service                           1      -     6.0M        -        -
/system.slice/system-mystuff.slice/process10.service                          4      -     1.4M        -        -
/system.slice/system-mystuff.slice/process11.service                          2      -     1.1M        -        -
/system.slice/system-mystuff.slice/process12.service                          1      -   620.0K        -        -
/system.slice/system-mystuff.slice/process13.service                          1      -   392.0K        -        -
/system.slice/system-mystuff.slice/process14.service                          1      -   308.0K        -        -
/system.slice/system-mystuff.slice/process15.service                          1      -   260.0K        -        -
/system.slice/system-mystuff.slice/process16.service                          1      -   184.0K        -        -
/system.slice/system-mystuff.slice/process17.service                          1      -   180.0K        -        -
/system.slice/system-mystuff.slice/process18.service                          1      -        -        -        -
/system.slice/system-mystuff.slice/process19.service                          1      -        -        -        -

列を合計すると、フラグメントのすべてのプロセスは約430 MBのメモリを使用します。

私の研究の一環として、私は見つけました。https://www.mjmwired.net/kernel/Documentation/cgroups/memory.txt セクション5.2と5.5は、メモリ使用量がRSS + CACHE(+ SWAP)として計算されることを示します。

https://www.mjmwired.net/kernel/Documentation/cgroups/memory.txt#560

確実にするために、/sys/fs/cgroup/memory/system.slice/system-mystuff.sliceファイルシステムを繰り返し、スライス内の各プロセスのmemory.statファイルを調べるスクリプトを作成しました。次に、各プロセスにtotal_rss + total_cache + total_swapを追加します。この合計の合計は約430MBに一致します。

だから私の質問は、systemd-cgtop2.3GBの数値をどこで得ることができるかということです。

答え1

メモリは共有されます。 glibcなどの共有ライブラリのコピーがあり、多くのユーザーがそれをメモリ使用量の一部としてカウントします。

関連情報