Я тільки вчора почав розбиратися в цьому для моїх потреб, нижче - те, що я знайшов досі:
SWAP_USED = Used_by_Process + SwapCched + Part_of_Tmpfs + something_else
Коротка розповідь:
Used_by_Process - дані, які повністю замінені з пам'яті.
SwapCched - дані, які були замінені на диск, але все ще залишаються в пам'яті.
Part_of_Tmpfs - деяка частина даних tmpfs.
Довга історія:
Used_by_Process - опубліковано багато вказівок про те, як неправильно підрахувати цей;) Наприклад, якщо ми підсумуємо всі VmSwap
записи з /proc/*/status
або Swap
записи з них /proc/*/smaps
- ми отримаємо завищену кількість (загальнодоступні розміщені сторінки можуть зараховуватися не один раз). Якщо ми не запустимо його від root
користувача або нашої ОС - недооцінене значення буде повернуто. У мене немає належного способу ідентифікації спільних сторінок, але бризкання тих самих "карт" дає набагато краще наближення, ніж інші підходи: (зауважте, що cat
нижче це не даремно і насправді потрібне 2>/dev/null
)
[root@a:~]# cat /proc/*/status|awk ' /^VmSwap/{ s+=$2 }END{print s}'
32048
[root@a:~]# cat /proc/*/smaps|awk ' /^Swap/{ s+=$2 }END{print s}'
32048
[root@a:~]# cat /proc/*/smaps|awk '/-/{r=$0}/^Swap/{if(R[r]!=1)s+=$2;R[r]=1}END{print s}'
14940
[root@a:~]# free -k|grep -e Swap -e used
total used free shared buffers cached
Swap: 8388600 15508 8373092
SwapCched - цей простий і з нього можна чисто витягти /proc/meminfo
. Деякі люди не очікують, що це буде зараховано як "використаний" своп, оскільки дублікат (не брудна) копія однієї і тієї ж сторінки в оперативній пам’яті та заміні може бути звільнений з обох сторін досить миттєво (у випадку, якщо з’явиться попит), таким чином один із примірників «звільнився».
Part_of_Tmpfs - яскрава сторона полягає в тому, що коли всі ваші дані tmpfs не торкаються багато днів і swappiness
є не нульовими - цілком ймовірно, що цілі tmpfs замінені (і навпаки, для нещодавно використаних даних). Недоліком є те, що я не знайшов API, який би достовірно обчислював поріг або відсоток від того, на скільки його обміняли, хоча якщо є достатня кількість оперативної пам’яті, ми можемо скопіювати цілі дані tmpfs /dev/null
і, таким чином, отримати деяку підказку, скільки її було замінено.
Поширені помилки, які робляться під час обчислення розміру tmpfs, - це припущення, що /dev/shm
це єдиний tmpfs, налаштований або намагається це зробити за допомогою рекурсивного сканування файлів (не тільки реалізація, як правило, опускає приховані файли або робить це з не- root
, але також відміняє місцями деякі сторінки під час переходу). Набагато простіший спосіб - це використовувати добрий старий df
.
something_else - дивіться " diff 385 MB
" нижче, потрібно зануритися в джерела ядра. Дивіться мій сценарій:
#!/bin/bash
TMPFS=`df -kP |awk ' /^tmpfs/{ s+=$3 }END{print int( s/1024)}'`
PROCS=`cat /proc/*/smaps|awk '/-/{r=$0} /^Swap/{if(R[r]!=1)s+=$2;R[r]=1}END{print int( s/1024)}'`
SCACH=`cat /proc/meminfo|awk ' /^SwapCached/ {print int($2/1024)}'`
TOTAL=`free -k |awk ' /^Swap/ {print int($3/1024)}'`
echo -e " df $TMPFS\t smaps $PROCS \tSwapCache $SCACH\t| $TOTAL\tswap | diff $[TOTAL-TMPFS-PROCS-SCACH]\tMB"
і вихід з різних коробок:
xa002: df 0 smaps 271 SwapCache 3858 | 4120 swap | diff -9 MB
sg003: df 0 smaps 234 SwapCache 3876 | 4111 swap | diff 1 MB
sg001: df 0 smaps 245 SwapCache 3845 | 4093 swap | diff 3 MB
sg002: df 0 smaps 244 SwapCache 3843 | 4091 swap | diff 4 MB
dm001: df 2 smaps 971 SwapCache 728 | 1707 swap | diff 6 MB
hm012: df 270 smaps 161 SwapCache 29 | 454 swap | diff -6 MB
hm003: df 274 smaps 142 SwapCache 27 | 440 swap | diff -3 MB
hm006: df 262 smaps 150 SwapCache 29 | 437 swap | diff -4 MB
hm002: df 265 smaps 120 SwapCache 28 | 412 swap | diff -1 MB
hm009: df 258 smaps 124 SwapCache 33 | 410 swap | diff -5 MB
hm011: df 262 smaps 118 SwapCache 28 | 406 swap | diff -2 MB
hm008: df 245 smaps 122 SwapCache 32 | 396 swap | diff -3 MB
hm005: df 247 smaps 120 SwapCache 33 | 396 swap | diff -4 MB
dp001: df 0 smaps 0 SwapCache 0 | 386 swap | diff 386 MB
hm014: df 184 smaps 134 SwapCache 34 | 343 swap | diff -9 MB
hm007: df 0 smaps 132 SwapCache 32 | 158 swap | diff -6 MB
bm002: df 0 smaps 121 SwapCache 25 | 141 swap | diff -5 MB
dm002: df 2 smaps 70 SwapCache 71 | 139 swap | diff -4 MB
bm001: df 3 smaps 102 SwapCache 28 | 131 swap | diff -2 MB
bm004: df 0 smaps 98 SwapCache 29 | 126 swap | diff -1 MB
hm013: df 0 smaps 100 SwapCache 30 | 124 swap | diff -6 MB
bm006: df 0 smaps 103 SwapCache 15 | 122 swap | diff 4 MB
hm010: df 0 smaps 102 SwapCache 24 | 122 swap | diff -4 MB
hm001: df 0 smaps 101 SwapCache 25 | 121 swap | diff -5 MB
bm003: df 0 smaps 98 SwapCache 15 | 107 swap | diff -6 MB
bm005: df 0 smaps 70 SwapCache 17 | 85 swap | diff -2 MB
sg004: df 0 smaps 72 SwapCache 14 | 83 swap | diff -3 MB
sg001: df 0 smaps 41 SwapCache 33 | 78 swap | diff 4 MB
sg005: df 0 smaps 59 SwapCache 20 | 75 swap | diff -4 MB
sg003: df 0 smaps 58 SwapCache 18 | 72 swap | diff -4 MB
sg006: df 0 smaps 56 SwapCache 13 | 65 swap | diff -4 MB
sg002: df 0 smaps 54 SwapCache 12 | 64 swap | diff -2 MB
xa001: df 0 smaps 56 SwapCache 5 | 55 swap | diff -6 MB
І невеликий експеримент як бонус:
[root@hm012:~]# df -h|grep -e '^Filesystem' -e '^tmpfs'
Filesystem Size Used Avail Use% Mounted on
tmpfs 12G 271M 12G 3% /dev/shm
tmpfs 8.0G 84K 8.0G 1% /tmp
[root@hm012:~]# ./get_swap.sh
df 270 smaps 161 SwapCache 29 | 454 swap | diff -6 MB
[root@hm012:~]# rm -rf /dev/shm/*
[root@hm012:~]# df -h|grep -e '^Filesystem' -e '^tmpfs'
Filesystem Size Used Avail Use% Mounted on
tmpfs 12G 0 12G 0% /dev/shm
tmpfs 8.0G 84K 8.0G 1% /tmp
[root@hm012:~]# ./get_swap.sh
df 0 smaps 161 SwapCache 29 | 185 swap | diff -5 MB
PS окрім згаданого вище наближення - є й інші джерела помилок, такі як округлення KB у МБ, теоретична можливість невідповідності між розмірами блоків оперативної пам’яті та свопом тощо. Я не впевнений, що це покриває все, але сподіваюся, що це допомагає певною мірою :)
VmSwap
рядку в/proc/PID/status
? Питання не вимагає кращого відображення, це питання, що може бути в свопі, крім даних про обробку.