Zabbix: solve memory and cpu load monitoring issues inside LXC containers
Nov 29, 2017 · 2 min read
Zabbix have some problems with memory collecting from cgroups limited containers.
If you using Promxox, you know what I mean: The available memory collected worng without calculating buffers and cache memory.
Zabbix have bug report, but it seems that no one don’t want to fix it soon.
So let’s fix it together byself.
First we need to create new user parameter for zabbix, I used ct.memory.size name similarly built-in vm.memory.size parameter, but with my own single line script.
Please be sure that you have newest version of free tool, 3.3.10 and higher, because old one have different output format.
E d it /etc/zabbix/zabbix_agentd.conf:
Add user parameter for retrieve memory information:
Add another one for retrieve swap information:
Add another one for retrieve right CPU load information:
Or just download and copy my zabbix_container.conf.
It will provide you support for next parameters:
Don’t forget to restart zabbix-agent.service after
Ok, now we can check is our parameter working from zabbix server:
Now let’s configure zabbix for use them. In Zabbix Interface:
Go Configuration → Templtes
- Make full copy “Template OS Linux” to “Template Linux Container”
- Open “Template Linux Container” → Items
- Replace all vm.memory.size items to ct.memory.size .
- Replace all system.swap.size items to ct.swap.size :
You also need to remove commas in key filed here. Example:
replace system.swap.size[,free] to ct.swap.size[free] - Replace all system.cpu.load[percpu,*] items to ct.cpu.load[percpu,* .
Next, go to the Configuration → Hosts
- Unlink and clear “Template OS Linux” from your hosts
- Attach “Template Linux Container”
Источник
Zabbix «High memory utilization»
Доброго времени суток.
С некоторого времени на одном из серверов с мониторингом Zabbix начал срабатывать триггер «High memory utilization».
На самом сервере 100 гигов памяти, занято всегда не больше 20. Причем сообщение выходит в нерабочее время, когда сервер по идее вообще не должен быть нагружен. Сервер виндовый, терминальный.
Также не до конца понятно, что означает сам триггер. На вики Заббикса это выражение просто не ищется. Залезла внутрь элемента данных. Ключ vm.memory.util, формула last(«vm.memory.size[used]») / last(«vm.memory.size[total]») * 100.
Судя по логике, используемая память сравнивается с общей, что и говорит о нагрузке сервера. Но дело в том, что сервер в принципе не использует больше 20% памяти.
В логах сервера тоже чисто.
Можете подсказать, в какую сторону копать, что именно смотреть, и, все-таки, о какой нагрузке говорит «High memory utilization»?
Ключ vm.memory.util, формула last(«vm.memory.size[used]») / last(«vm.memory.size[total]») * 100.
Какой-то свой шаблон? Логично спросить у автора
So inactive memory is both used and available simultaneously. Because of this, the vm.memory.size[used] item is designed for informational purposes only, while vm.memory.size[available] is designed to be used in triggers
- всегда можно посмотреть график одного item’а чтобы понять, это какой-то сбой в получении данных или памяти действительно мало
и, все-таки, о какой нагрузке говорит «High memory utilization»?
Кто мешает посмотреть код агента?
Причем сообщение выходит в нерабочее время, когда сервер по идее вообще не должен быть нагружен. Сервер виндовый, терминальный.
Кстати, в нерабочее время обычно ставятся обновления
Источник
Нехватка памяти на сервере
Не так давно я создавал тред, где переживал что апач с одним единственным сайтом из хмтл страничек отжирает всю память на серваке. Меня успокоили, что он отжирает свободную память под кеш, что свободная память все равно никак не используется и как только она понадобится, то апач мне её вернет. Прошло несколько месяцев, сервер никто не трогал. Сегодня установил zabbix и он сразу же выдал мне сообщение о проблеме Lack of free swap space on Zabbix server. Получается память для него так и не освободилась? Как с этим боротся? Не может же быть такого, что apache2 со статическим сайтом + zabbix отжирают 2 гигабайта оперативки?
Не ужеле не можете посмотреть, кто сколько памяти отжирает?
Судя по выводу free — cвоп у вас не подключен\отсутствует, соответственно свободного пространства в нем 0.
Апач всё отжирает. Поидее он должен отжирать неиспользуемую память для убыстрения работы, но вот сейчас память нужна, а он её не отдает
Lack of free swap space (Отсутствие свободного пространства подкачки)
Не может же быть такого, что apache2 со статическим сайтом + zabbix отжирают 2 гигабайта оперативки?
Вот сколько памяти у тебя занято приложениями.
Странно, VPS машину создали без свапа получается? теперь вручную его пилить
Источник
Zabbix Documentation 3.0
Sidebar
Table of Contents
1 Zabbix agent
Overview
These checks use the communication with Zabbix agent for data gathering.
There are passive and active agent checks. When configuring an item, you can select the required type:
Supported item keys
The table provides details on the item keys that you can use with Zabbix agent items.
Mandatory and optional parameters
Parameters without angle brackets are mandatory. Parameters marked with angle brackets are optional.
Key | ||||
---|---|---|---|---|
Description | Return value | Parameters | Comments | |
agent.hostname | ||||
Agent host name. | String | Returns the actual value of the agent hostname from a configuration file. | ||
agent.ping | ||||
Agent availability check. | Nothing — unavailable |
1 — available
1.8.2
regexp — regular expression describing the required pattern
encoding — code page identifier
maxlines — maximum number of new lines per second the agent will send to Zabbix server or proxy. This parameter overrides the value of ‘MaxLinesPerSecond’ in zabbix_agentd.conf
mode — possible values:
all (default), skip — skip processing of older data (affects only newly created items).
output — an optional output formatting template. The \0 escape sequence is replaced with the matched part of text (from the first character where match begins until the character where match ends) while an \N (where N=1…9) escape sequence is replaced with Nth matched group (or an empty string if the N exceeds the number of captured groups).
If file is missing or permissions do not allow access, item turns unsupported.
If output is left empty — the whole line containing the matched text is returned. Note that all global regular expression types except ‘Result is TRUE’ always return the whole matched line and the output parameter is ignored.
Content extraction using the output parameter takes place on the agent.
Examples:
⇒ log[/var/log/syslog]
⇒ log[/var/log/syslog,error]
⇒ log[/home/zabbix/logs/logfile. 100]
Example of using output parameter for extracting a number from log record:
log[/app1/app.log,»task run [0-9.]+ sec, processed (9+) records, 6+ errors». \1]→ will match a log record «2015-11-13 10:08:26 task run 6.08 sec, processed 6080 records, 0 errors» and send only number 6080 to server. Because a number is being sent, the «Type of information» for this log item can be changed from «Log» to «Numeric (unsigned)» and the value can be used in graphs, triggers etc.
Example of using output parameter for rewriting log record before sending to server:
log[/app1/app.log,»([0-9 :-]+) task run ([0-9.]+) sec, processed (9+) records, (3+) errors». «\1 RECORDS: \3, ERRORS: \4, DURATION: \2»]→ will match a log record «2015-11-13 10:08:26 task run 6.08 sec, processed 6080 records, 0 errors » and send a modified record «2015-11-13 10:08:26 RECORDS: 6080, ERRORS: 0, DURATION: 6.08» to server.
The output parameter is supported since Zabbix 2.2.
The mode parameter is supported since Zabbix 2.0.
See also additional information on log monitoring.
regexp — regular expression describing the required content pattern
encoding — code page identifier
maxlines — maximum number of new lines per second the agent will send to Zabbix server or proxy. This parameter overrides the value of ‘MaxLinesPerSecond’ in zabbix_agentd.conf
mode — possible values:
all (default), skip — skip processing of older data (affects only newly created items).
output — an optional output formatting template. The \0 escape sequence is replaced with the matched part of text (from the first character where match begins until the character where match ends) while an \N (where N=1…9) escape sequence is replaced with Nth matched group (or an empty string if the N exceeds the number of captured groups).
Log rotation is based on the last modification time of files.
Note that logrt is designed to work with one currently active log file, with several other matching inactive files rotated. If, for example, a directory has many active log files, a separate logrt item should be created for each one. Otherwise if one logrt item picks up too many files it may lead to exhausted memory and a crash of monitoring.
If output is left empty — the whole line containing the matched text is returned. Note that all global regular expression types except ‘Result is TRUE’ always return the whole matched line and the output parameter is ignored.
Content extraction using the output parameter takes place on the agent.
Examples:
⇒ logrt[«/home/zabbix/logs/^logfile5<1,3>$». 100] → will match a file like «logfile1» (will not match «.logfile1»)
⇒ logrt[«/home/user/^logfile_.*_5<1,3>$»,»pattern_to_match»,»UTF-8″,100] → will collect data from files such «logfile_abc_1» or «logfile__001».
Example of using output parameter for extracting a number from log record:
logrt[/app1/^test.*log$,»task run [0-9.]+ sec, processed (7+) records, 4+ errors». \1]→ will match a log record «2015-11-13 10:08:26 task run 6.08 sec, processed 6080 records, 0 errors» and send only number 6080 to server. Because a number is being sent, the «Type of information» for this log item can be changed from «Log» to «Numeric (unsigned)» and the value can be used in graphs, triggers etc.
Example of using output parameter for rewriting log record before sending to server:
logrt[/app1/^test.*log$,»([0-9 :-]+) task run ([0-9.]+) sec, processed (1+) records, (4+) errors». «\1 RECORDS: \3, ERRORS: \4, DURATION: \2»]→ will match a log record «2015-11-13 10:08:26 task run 6.08 sec, processed 6080 records, 0 errors » and send a modified record «2015-11-13 10:08:26 RECORDS: 6080, ERRORS: 0, DURATION: 6.08» to server.
The output parameter is supported since Zabbix 2.2.
The mode parameter is supported since Zabbix 2.0.
See also additional information on log monitoring.
]
Internationalized domain names are not supported, please use IDNA encoded names instead.
The protocol parameter is supported since Zabbix 3.0.
SRV record type is supported since Zabbix agent versions 1.8.6 (Unix) and 2.0.0 (Windows).
Naming before Zabbix 2.0 (still supported): net.tcp.dns
]
name — DNS name to query
type — record type to be queried (default is SOA)
timeout (ignored on Windows) — timeout for the request in seconds (default is 1 second)
count (ignored on Windows) — number of tries for the request (default is 2)
protocol — the protocol used to perform DNS queries: udp (default) or tcp
⇒ net.dns.record[8.8.8.8,zabbix.com,MX,2,1]
Internationalized domain names are not supported, please use IDNA encoded names instead.
The protocol parameter is supported since Zabbix 3.0.
SRV record type is supported since Zabbix agent versions 1.8.6 (Unix) and 2.0.0 (Windows).
Naming before Zabbix 2.0 (still supported): net.tcp.dns.query
On FreeBSD, OpenBSD and NetBSD supported since Zabbix agent version 2.2.
Some Windows versions (for example, Server 2008) might require the latest updates installed to support non-ASCII characters in interface names.
mode — possible values:
bytes — number of bytes (default)
packets — number of packets
errors — number of errors
dropped — number of dropped packets
Multi-byte interface names on Windows are supported since Zabbix agent version 1.8.6.
Examples:
⇒ net.if.in[eth0,errors]
⇒ net.if.in[eth0]
You may obtain network interface descriptions on Windows with net.if.discovery or net.if.list items.
You may use this key with a Delta (speed per second) store value in order to get bytes per second statistics.
mode — possible values:
bytes — number of bytes (default)
packets — number of packets
errors — number of errors
dropped — number of dropped packets
Multi-byte interface names on Windows are supported since Zabbix agent 1.8.6 version.
Examples:
⇒ net.if.out[eth0,errors]
⇒ net.if.out[eth0]
You may obtain network interface descriptions on Windows with net.if.discovery or net.if.list items.
You may use this key with a Delta (speed per second) store value in order to get bytes per second statistics.
mode — possible values:
bytes — number of bytes (default)
packets — number of packets
errors — number of errors
dropped — number of dropped packets
Examples:
⇒ net.if.total[eth0,errors]
⇒ net.if.total[eth0]
You may obtain network interface descriptions on Windows with net.if.discovery or net.if.list items.
You may use this key with a Delta (speed per second) store value in order to get bytes per second statistics.
Note that dropped packets are supported only if both net.if.in and net.if.out work for dropped packets on your platform.
1 — it is in LISTEN state
⇒ net.tcp.listen[80]
On Linux supported since Zabbix agent version 1.8.4
Since Zabbix 3.0.0, on Linux kernels 2.6.14 and above, information about listening TCP sockets is obtained from the kernel’s NETLINK interface, if possible. Otherwise, the information is retrieved from /proc/net/tcp and /proc/net/tcp6 files.
1 — can connect
port — port number
⇒ net.tcp.port[,80] → can be used to test availability of web server running on port 80.
For simple TCP performance testing use net.tcp.service.perf[tcp, ,
Note that these checks may result in additional messages in system daemon logfiles (SMTP and SSH sessions being logged usually).
Old naming: check_port[*]
]
1 — service is running
ssh, ldap, smtp, ftp, http, pop, nntp, imap, tcp, https, telnet (see details)
ip — IP address (default is 127.0.0.1)
port — port number (by default standard service port number is used)
⇒ net.tcp.service[ftp,,45] → can be used to test the availability of FTP server on TCP port 45.
Note that these checks may result in additional messages in system daemon logfiles (SMTP and SSH sessions being logged usually).
Checking of encrypted protocols (like IMAP on port 993 or POP on port 995) is currently not supported. As a workaround, please use net.tcp.port for checks like these.
Checking of LDAP and HTTPS by Windows agent is currently not supported.
Note that the telnet check looks for a login prompt (‘:’ at the end).
See also known issues of checking HTTPS service.
https and telnet services are supported since Zabbix 2.0.
Old naming: check_service[*]
]
seconds — the number of seconds spent while connecting to the service
ssh, ldap, smtp, ftp, http, pop, nntp, imap, tcp, https, telnet (see details)
ip — IP address (default is 127.0.0.1)
port — port number (by default standard service port number is used)
⇒ net.tcp.service.perf[ssh] → can be used to test the speed of initial response from SSH server.
Checking of encrypted protocols (like IMAP on port 993 or POP on port 995) is currently not supported. As a workaround, please use net.tcp.service.perf[tcp, ,
] for checks like these.
Checking of LDAP and HTTPS by Windows agent is currently not supported.
Note that the telnet check looks for a login prompt (‘:’ at the end).
See also known issues of checking HTTPS service.
https and telnet services are supported since Zabbix 2.0.
Old naming: check_service_perf[*]
1 — it is in LISTEN state
⇒ net.udp.listen[68]
On Linux supported since Zabbix agent version 1.8.4
]
1 — service is running
ip — IP address (default is 127.0.0.1)
port — port number (by default standard service port number is used)
⇒ net.udp.service[ntp,,45] → can be used to test the availability of NTP service on UDP port 45.
This item is supported since Zabbix 3.0.0, but ntp service was available for net.tcp.service[] item in prior versions.
]
seconds — the number of seconds spent waiting for response from the service
ip — IP address (default is 127.0.0.1)
port — port number (by default standard service port number is used)
⇒ net.udp.service.perf[ntp] → can be used to test response time from NTP service.
This item is supported since Zabbix 3.0.0, but ntp service was available for net.tcp.service[] item in prior versions.
user — user name (default is all users)
type — CPU utilisation type:
total (default), user, system
cmdline — filter by command line (it is a regular expression)
mode — data gathering mode: avg1 (default), avg5, avg15
zone — target zone: current (default), all. This parameter is supported only on Solaris platform.
⇒ proc.cpu.util[,root] → CPU utilisation of all processes running under the “root” user
⇒ proc.cpu.util[zabbix_server,zabbix] → CPU utilisation of all zabbix_server processes running under the zabbix user
The returned value is based on single CPU core utilisation percentage. For example CPU utilisation of a process fully using two cores is 200%.
The process CPU utilisation data is gathered by a collector which supports the maximum of 1024 unique (by name, user and command line) queries. Queries not accessed during the last 24 hours are removed from the collector.
Note that when setting the zone parameter to current (or default) in case the agent has been compiled on a Solaris without zone support, but running on a newer Solaris where zones are supported, then the agent since Zabbix 3.0.3 will return NOTSUPPORTED (the agent cannot limit results to only the current zone). However, all is supported in this case.
This key is supported since Zabbix 3.0.0 and is available on several platforms (see Items supported by platform).
Float — with mode as avg
user — user name (default is all users)
mode — possible values:
avg, max, min, sum (default)
cmdline — filter by command line (it is a regular expression)
memtype — type of memory used by process
⇒ proc.mem[,root] → memory used by all processes running under the “root” user
⇒ proc.mem[zabbix_server,zabbix] → memory used by all zabbix_server processes running under the zabbix user
⇒ proc.mem[,oracle,max,oracleZABBIX] → memory used by the most memory-hungry process running under oracle having oracleZABBIX in its command line
Note: When several processes use shared memory, the sum of memory used by processes may result in large, unrealistic values.
See notes on selecting processes with name and cmdline parameters (Linux-specific).
When this item is invoked from the command line and contains a command line parameter (e.g. using the agent test mode: zabbix_agentd -t proc.mem[. apache2] ), one extra process will be counted, as the agent will count itself.
The memtype parameter is supported on several platforms since Zabbix 3.0.0.
user — user name (default is all users)
state — possible values: all (default), run, sleep, zomb
cmdline — filter by command line (it is a regular expression)
zone — target zone: current (default), all. This parameter is supported on Solaris only.
⇒ proc.num[,mysql] → number of processes running under the mysql user
⇒ proc.num[apache2,www-data] → number of apache2 processes running under the www-data user
⇒ proc.num[,oracle,sleep,oracleZABBIX] → number of processes in sleep state running under oracle having oracleZABBIX in its command line
See notes on selecting processes with name and cmdline parameters (Linux-specific).
When this item is invoked from the command line and contains a command line parameter (e.g. using the agent test mode: zabbix_agentd -t proc.num[. apache2] ), one extra process will be counted, as the agent will count itself.
On Windows, only the name and user parameters are supported.
The zone parameter is supported on Solaris since Zabbix 3.0.21. Note that when setting the zone parameter to current (or default) in case the agent has been compiled on a Solaris without zone support, but running on a newer Solaris where zones are supported, then the agent will return NOTSUPPORTED (the agent cannot limit results to only the current zone). However, all is supported in this case.
sensor — sensor name
mode — possible values:
avg, max, min (if this parameter is omitted, device and sensor are treated verbatim).
Prior to Zabbix 1.8.4, the sensor[temp1] format was used.
See a more detailed description of sensor item on Linux.
Examples:
⇒ sensor[cpu0,temp0] → temperature of one CPU
⇒ sensor[«cpu2$»,temp,avg] → average temperature of the first three CPU’s
Supported on OpenBSD since Zabbix 1.8.4.
all (default), percpu (total load divided by online CPU count)
mode — possible values:
avg1 (one-minute average, default), avg5, avg15
⇒ system.cpu.load[,avg5]
percpu is supported since Zabbix 2.0.0.
Old naming: system.cpu.loadX
online (default), max
⇒ system.cpu.num
type — possible values:
idle, nice, user (default), system (default for Windows), iowait, interrupt, softirq, steal, guest (on Linux kernels 2.6.24 and above), guest_nice (on Linux kernels 2.6.33 and above). Parameters user and nice time no longer include guest time and guest_nice time since Zabbix 3.0.14.
See also platform-specific details for this parameter.
mode — possible values:
avg1 (one-minute average, default), avg5, avg15
⇒ system.cpu.util[0,user,avg5]
Old naming: system.cpu.idleX, system.cpu.niceX, system.cpu.systemX, system.cpu.userX
Examples of returned values:
on Linux:
⇒ system.hostname → linux-w7x1
⇒ system.hostname → www.zabbix.com
on Windows:
⇒ system.hostname → WIN-SERV2008-I6
⇒ system.hostname[host] → Win-Serv2008-I6LonG
The type parameter for this item is supported since Zabbix 1.8.6.
See also a more detailed description.
Hewlett-Packard HP Pro 3010 Small Form Factor PC CZXXXXXXXX Desktop]
This key depends on the availability of the SMBIOS table.
Will try to read the DMI table from sysfs, if sysfs access fails then try reading directly from memory.
Root permissions are required because the value is acquired by reading from sysfs or memory.
Supported since Zabbix agent version 2.0.
info — possible values:
full (default), curfreq, maxfreq, model or vendor
⇒ system.hw.cpu[0,vendor] → AuthenticAMD
Gathers info from /proc/cpuinfo and /sys/devices/system/cpu/[cpunum]/cpufreq/cpuinfo_max_freq.
If a CPU number and curfreq or maxfreq is specified, a numeric value is returned (Hz).
Supported since Zabbix agent version 2.0.
⇒ system.hw.devices[pci] → 00:00.0 Host bridge: Advanced Micro Devices [AMD] RS780 Host Bridge
[..]
Returns the output of either lspci or lsusb utility (executed without any parameters)
Supported since Zabbix agent version 2.0.
format — full (default) or short
Example:
⇒ system.hw.macaddr[«eth0$»,full] → [eth0] 00:11:22:33:44:55
If format is specified as short, interface names and identical MAC addresses are not listed.
Supported since Zabbix agent version 2.0.
String — with type as local
utc — (default) the time since the Epoch (00:00:00 UTC, January 1, 1970), measured in seconds.
local — the time in the ‘yyyy-mm-dd,hh:mm:ss.nnn,+hh:mm’ format
Example:
⇒ system.localtime[local] → create an item using this key and then use it to display host time in the Clock screen element.
1 — with mode as nowait (regardless of command result)
mode — possible values:
wait — wait end of execution (default),
nowait — do not wait
To be processed correctly, the output of the command must be text.
Example:
⇒ system.run[ls -l /] → detailed file list of root directory.
Note: To enable this functionality, agent configuration file must contain EnableRemoteCommands=1 option.
Note: The return value of the item is standard output together with standard error produced by command.
Note: Empty result is allowed starting with Zabbix 2.4.0.
See also: Command execution.
kthr, — information about kernel thread states:
r — average number of runnable kernel threads (float)
b — average number of kernel threads placed in the Virtual Memory Manager wait queue (float)
memory, — information about the usage of virtual and real memory:
avm — active virtual pages (integer)
fre — size of the free list (integer)
page, — information about page faults and paging activity:
fi — file page-ins per second (float)
fo — file page-outs per second (float)
pi — pages paged in from paging space (float)
po — pages paged out to paging space (float)
fr — pages freed (page replacement) (float)
sr — pages scanned by page-replacement algorithm (float)
faults, — trap and interrupt rate:
in — device interrupts (float)
sy — system calls (float)
cs — kernel thread context switches (float)
cpu, — breakdown of percentage usage of processor time:
us — user time (float)
sy — system time (float)
id — idle time (float)
wa — idle time during which the system had outstanding disk/NFS I/O request(s) (float)
pc — number of physical processors consumed (float)
ec — the percentage of entitled capacity consumed (float)
lbusy — indicates the percentage of logical processor(s) utilization that occurred while executing at the user and system level (float)
app — indicates the available physical processors in the shared pool (float)
disk, — disk statistics:
bps — indicates the amount of data transferred (read or written) to the drive in bytes per second (integer)
tps — indicates the number of transfers per second that were issued to the physical disk/tape (float)
The following items are supported only on AIX LPAR of type “Shared”:
⇒ system.stat[cpu,app]
⇒ system.stat[cpu,ec] (also on “Dedicated” since Zabbix 3.0.23; always returns 100 (percent))
⇒ system.stat[cpu,lbusy]
⇒ system.stat[cpu,pc] (also on “Dedicated” since Zabbix 3.0.23)
⇒ system.stat[ent] (also on “Dedicated” since Zabbix 3.0.23)
⇒ system.sw.arch → i686
Info is acquired from uname() function.
Supported since Zabbix agent version 2.0.
full (default), short or name
⇒ system.sw.os[short]→ Ubuntu 2.6.35-28.50-generic 2.6.35.11
Info is acquired from (note that not all files are present in all distributions):
/proc/version (full)
/proc/version_signature (short)
/etc/issue.net (name)
Supported since Zabbix agent version 2.0.
, , ]
manager — all (default) or a package manager
format — full (default) or short
Example:
⇒ system.sw.packages[mini,dpkg,short] → python-minimal, python2.6-minimal, ubuntu-minimal
Supported package managers (executed command):
dpkg (dpkg —get-selections)
pkgtool (ls /var/log/packages)
rpm (rpm -qa)
pacman (pacman -Q)
If format is specified as full, packages are grouped by package managers (each manager on a separate line beginning with its name in square brackets).
If format is specified as short, packages are not grouped and are listed on a single line.
Supported since Zabbix agent version 2.0.
type — possible values:
count (number of swapins), sectors (sectors swapped in), pages (pages swapped in).
See also platform-specific details for this parameter.
⇒ system.swap.in[,pages]
The source of this information is:
/proc/swaps, /proc/partitions, /proc/stat (Linux 2.4)
/proc/swaps, /proc/diskstats, /proc/vmstat (Linux 2.6)
type — possible values:
count (number of swapouts), sectors (sectors swapped out), pages (pages swapped out).
See also platform-specific details for this parameter.
⇒ system.swap.out[,pages]
The source of this information is:
/proc/swaps, /proc/partitions, /proc/stat (Linux 2.4)
/proc/swaps, /proc/diskstats, /proc/vmstat (Linux 2.6)
Float — for percentage
type — possible values:
free (free swap space, default), pfree (free swap space, in percent), pused (used swap space, in percent), total (total swap space), used (used swap space)
See also platform-specific details for this parameter.
⇒ system.swap.size[,pfree] → free swap space percentage
If device is not specified Zabbix agent will only take into account swap devices (files), physical memory will be ignored. For example, on Solaris systems swap -s command includes a portion of physical memory and swap devices (unlike swap -l).
Note that this key might report incorrect swap space size/percentage on virtualized (VMware ESXi, VirtualBox) Windows platforms. In this case you may use the perf_counter[\700(_Total)\702] key to obtain correct swap space percentage.
Old naming: system.swap.free, system.swap.total
FreeBSD localhost 4.2-RELEASE FreeBSD 4.2-RELEASE #0: Mon Nov i386
Example of returned value (Windows):
Windows ZABBIX-WIN 6.0.6001 Microsoft® Windows Server® 2008 Standard Service Pack 1 x86
On Unix since Zabbix 2.2.0 the value for this item is obtained with uname() system call. Previously it was obtained by invoking “uname -a”. The value of this item might differ from the output of “uname -a” and does not include additional information that “uname -a” prints based on other sources.
On Windows since Zabbix 3.0 the value for this item is obtained from Win32_OperatingSystem and Win32_Processor WMI classes. Previously it was obtained from volatile Windows APIs and undocumented registry keys. The OS name (including edition) might be translated to the user’s display language. On some versions of Windows it contains trademark symbols and extra spaces.
Note that on Windows the item returns OS architecture, whereas on Unix it returns CPU architecture.
Float — with type in sps, ops, bps
Note: Since 3.0.25, if using an update interval of three hours or more 2 , will always return ‘0’
type — possible values: sectors, operations, bytes, sps, ops, bps
Note that ‘type’ parameter support and defaults depend on the platform. See platform-specific details.
sps, ops, bps stand for: sectors, operations, bytes per second, respectively.
mode — possible values: avg1 (one-minute average, default), avg5, avg15.
This parameter is supported only with type in: sps, ops, bps.
LVM logical volumes are supported.
Default values of ‘type’ parameter for different OSes:
AIX — operations
FreeBSD — bps
Linux — sps
OpenBSD — operations
Solaris — bytes
sps, ops and bps on supported platforms used to be limited to 8 devices (7 individual and one all). Since Zabbix 2.0.1 this limit is 1024 devices (1023 individual and one for all).
Old naming: io[*]
Float — with type in sps, ops, bps
Note: Since 3.0.25, if using an update interval of three hours or more 2 , will always return ‘0’
type — possible values: sectors, operations, bytes, sps, ops, bps
Note that ‘type’ parameter support and defaults depend on the platform. See platform-specific details.
sps, ops, bps stand for: sectors, operations, bytes per second, respectively.
mode — possible values: avg1 (one-minute average, default), avg5, avg15.
This parameter is supported only with type in: sps, ops, bps.
LVM logical volumes are supported.
Default values of ‘type’ parameter for different OSes:
AIX — operations
FreeBSD — bps
Linux — sps
OpenBSD — operations
Solaris — bytes
sps, ops and bps on supported platforms used to be limited to 8 devices (7 individual and one all). Since Zabbix 2.0.1 this limit is 1024 (1023 individual and one for all).
Old naming: io[*]
⇒ vfs.file.cksum[/etc/passwd]
Example of returned value:
1938292000
Old naming: cksum
The file size limit depends on large file support.
encoding — code page identifier
This item is limited to files no larger than 64 Kbytes.
Supported since Zabbix agent version 2.0.
1 — regular file or a link (symbolic or hard) to regular file exists
⇒ vfs.file.exists[/tmp/application.pid]
The return value depends on what S_ISREG POSIX macro returns.
The file size limit depends on large file support.
⇒ vfs.file.md5sum[/usr/local/etc/zabbix_agentd.conf]
Example of returned value:
b5052decb577e0fffd622d6ddc017e82
The file size limit depends on large file support.
regexp — GNU regular expression
encoding — code page identifier
start line — the number of first line to search (first line of file by default).
end line — the number of last line to search (last line of file by default).
output — an optional output formatting template. The \0 escape sequence is replaced with the matched part of text (from the first character where match begins until the character where match ends) while an \N (where N=1…9) escape sequence is replaced with Nth matched group (or an empty string if the N exceeds the number of captured groups).
An empty string is returned if no line matched the expression.
Content extraction using the output parameter takes place on the agent.
The start line , end line and output parameters are supported from version 2.2.
Examples:
⇒ vfs.file.regexp[/etc/passwd,zabbix]
⇒ vfs.file.regexp[/path/to/some/file,»(9+)$»,,3,5,\1]
⇒ vfs.file.regexp[/etc/passwd,»^zabbix. (1+)». \1] → getting the ID of user zabbix
1 — found
regexp — GNU regular expression
encoding — code page identifier
start line — the number of first line to search (first line of file by default).
end line — the number of last line to search (last line of file by default).
Example:
⇒ vfs.file.regmatch[/var/log/app.log,error]
The file size limit depends on large file support.
mode — possible values:
modify (default) — last time of modifying file content,
access — last time of reading file,
change — last time of changing file properties
⇒ vfs.file.time[/etc/passwd,modify]
The file size limit depends on large file support.
<#FSDRIVETYPE>macro is supported on Windows since Zabbix agent version 3.0.
Float — for percentage
mode — possible values:
total (default), free, used, pfree (free, percentage), pused (used, percentage)
⇒ vfs.fs.inode[/,pfree]
Old naming: vfs.fs.inode.free[*], vfs.fs.inode.pfree[*], vfs.fs.inode.total[*]
Float — for percentage
mode — possible values:
total (default), free, used, pfree (free, percentage), pused (used, percentage)
Reserved space of a file system is taken into account and not included when using the free mode.
Old naming: vfs.fs.free[*], vfs.fs.total[*], vfs.fs.used[*], vfs.fs.pfree[*], vfs.fs.pused[*]
Float — for percentage
total (default), active, anon, buffers, cached, exec, file, free, inactive, pinned, shared, wired, used, pused (used, percentage), available, pavailable (available, percentage)
See also platform-specific support and additional details for this parameter.
1) total — total amount of memory;
2) platform-specific memory types: active, anon, buffers, cached, exec, file, free, inactive, pinned, shared, wired;
3) user-level estimates on how much memory is used and available: used, pused, available, pavailable.
]
path — path to HTML document (default is /)
port — port number (default is 80)
Note that before version 3.0.17 it would return an empty string on fail.
Example:
⇒ web.page.get[www.zabbix.com,index.php,80]
]
path — path to HTML document (default is /)
port — port number (default is 80)
Note that before version 3.0.17 it would return ‘0’ on fail.
Example:
⇒ web.page.perf[www.zabbix.com,index.php,80]
,regexp, , ]
path — path to HTML document (default is /)
port — port number (default is 80)
regexp — GNU regular expression
length — maximum number of characters to return
output — an optional output formatting template. The \0 escape sequence is replaced with the matched part of text (from the first character where match begins until the character where match ends) while an \N (where N=1…9) escape sequence is replaced with Nth matched group (or an empty string if the N exceeds the number of captured groups).
Note that before version 3.0.17 it would return an empty string if no match was found or on fail.
Content extraction using the output parameter takes place on the agent.
The output parameter is supported from version 2.2.
Example:
⇒ web.page.regexp[www.zabbix.com,index.php,80,OK,2]
Footnotes
1 A Linux-specific note. Zabbix agent must have read-only access to filesystem /proc. Kernel patches from www.grsecurity.org limit access rights of non-privileged users.
2 vfs.dev.read[] , vfs.dev.write[] : Starting with Zabbix 3.0.25 Zabbix agent will terminate «stale» device connections if the item values are not accessed for more than 3 hours. This may happen if a system has devices with dynamically changing paths or if a device gets manually removed. Note also that these items, if using an update interval of 3 hours or more, will always return ‘0’.
3 vfs.dev.read[] , vfs.dev.write[] : If default all is used for the first parameter then the key will return summary statistics, including all block devices like sda, sbd and their partitions (sda1, sda2, sdb3…) and multiple devices (MD raid) based on those block devices/partitions and logical volumes (LVM) based on those block devices/partitions. In such cases returned values should be considered only as relative value (dynamic in time) but not as absolute values.
Available encodings
The encoding parameter is used to specify encoding for processing corresponding item checks, so that data acquired will not be corrupted. For a list of supported encodings (code page identifiers), please consult respective documentation, such as documentation for libiconv (GNU Project) or Microsoft Windows SDK documentation for “Code Page Identifiers”.
If empty encoding is passed, then UTF-8 (default locale for newer Unix/Linux distributions, see your system’s settings) or ANSI with system-specific extension (Windows) is used by default.
Источник