В этом разделе представлены некоторые подробности относительно элемента данных vm.memory.size[<режим>] агента Zabbix.
В этом элементе данных разрешены следующие параметры:
available/total*100).used/total*100).Некоторые из этих параметров работают только для конкретных платформ и могут быть недоступны на вашей платформе. См. Поддерживаемые элементы данных по платформам.
Вычисления available и used в зависимости от платформы:
| Платформа | "available" | "used" |
|---|---|---|
| AIX | free + cached | реальное использование памяти |
| FreeBSD | inactive + cached + free | active + wired + cached |
| HP UX | free | total - free |
| Linux<3.14 | free + buffers + cached | total - free |
| Linux 3.14+ (также перенесено для 3.10 на RHEL 7) |
/proc/meminfo, см. описание "MemAvailable" в документации ядра Linux [en]. Обратите внимание, что free + buffers + cached больше не равняется 'available', так как не весь кэш страницы может быть освобождён и в расчетах используется минимальный объем свободной памяти, зарезервированной системой (low watermark). |
total - free |
| NetBSD | inactive + execpages + file + free | total - free |
| OpenBSD | inactive + free + cached | active + wired |
| OSX | inactive + free | active + wired |
| Solaris | free | total - free |
| Win32 | free | total - free |
Сумма vm.memory.size[used] и vm.memory.size[available] не обязательно равна общему количеству памяти. Например, для FreeBSD:
* Активная, неактивная, wired, кэшируемая памяти считаются использованными, так как содержат некоторую полезную информацию.
* В то же время неактивная, кэшируемая, свободная памяти считаются доступными, так как такая память может быть незамедлительно освобождена процессу, который запросил больше памяти.
Таким образом, неактивная память помечается и как занятая, так и как свободная одновременно. Из-за этого элемент данных vm.memory.size[used] задумывался исключительно в информационных целях, тогда как элемент данных vm.memory.size[available] предназначен для использования в триггерах.