Check cpu-usage
Overview
Returns a bunch of numbers representing the current system-wide CPU utilization as a percentage. Outputs the cpu times having > 0% in the first line, sorted by value. In addition, the top 5 processes which consumed the most CPU time are listed. Warns only if any of user
, system
, iowait
or overall cpu-usage
is above a certain threshold within the last n checks (default: 5).
Hints and Recommendations:
We check system-wide CPU stats, not per-CPU.
--count=5
(the default) while checking every minute means that the check reports a warning if any ofuser
,system
,iowait
or overallcpu-usage
was above a threshold in the last 5 minutes.Check needs at least 250ms to run.
Fact Sheet
Check Plugin Download |
https://github.com/Linuxfabrik/monitoring-plugins/tree/main/check-plugins/cpu-usage |
Check Interval Recommendation |
Once a minute |
Can be called without parameters |
Yes |
Compiled for |
Linux, Windows |
3rd Party Python modules |
|
Handles Periods |
Yes |
Uses SQLite DBs |
|
Help
usage: cpu-usage [-h] [-V] [--always-ok] [--count COUNT] [-c CRIT] [--top TOP]
[-w WARN]
Mainly provides utilization percentages for each specific CPU time. Takes a
time period into account: the cpu usage within a certain amount of time has to
be equal or above given thresholds before a warning is raised.
options:
-h, --help show this help message and exit
-V, --version show program's version number and exit
--always-ok Always returns OK.
--count COUNT Number of times the value must exceed specified
thresholds before alerting. Default: 5
-c, --critical CRIT Set the critical threshold CPU Usage Percentage.
Default: 90
--top TOP List x "Top processes using the most cpu time".
Default: 5
-w, --warning WARN Set the warning threshold CPU Usage Percentage.
Default: 80
Usage Examples
./cpu-usage --count=15 --warning=50 --critical=70
Output:
2.6% - user: 1.6%, system: 0.7%, irq: 0.2%, softirq: 0.1%
guest: 0.0%, iowait: 0.0%, guest_nice: 0.0%, steal: 0.0%, nice: 0.0%
interrupts: 582.9M, soft_interrupts: 343.6M, ctx_switches: 1.1G
Top3 processes using the most cpu time:
1. Xorg: 2h 13m
2. gnome-shell: 2h 1m
3. firefox: 1h 24m
States
OK if
user
,system
,iowait
and overallcpu-usage
(minusnice
) are all below the thresholds within the last--count
checks.Otherwise CRIT or WARN.
Perfdata / Metrics
Name |
Type |
Description |
---|---|---|
cpu-usage |
Percentage |
The overall cpu usage. This is (100 - |
ctx_switches |
Continous Counter |
Number of context switches (voluntary + involuntary) since boot. A context switch is a procedure that a computer’s CPU (central processing unit) follows to change from one task (or process) to another while ensuring that the tasks do not conflict. |
guest |
Percentage |
Linux 2.6.24+: Time spent running a virtual CPU. |
guest_nice |
Percentage |
Linux 3.2.0+ |
idle |
Percentage |
If the CPU has completed all tasks it is idle. |
interrupts |
Continous Counter |
Number of interrupts since boot. |
iowait |
Percentage |
Time spent waiting for I/O to complete. This is not accounted in idle time counter. |
irq |
Percentage |
Time spent for servicing hardware interrupts. |
nice |
Percentage |
Time spent by niced (prioritized) processes executing in user mode; this also includes guest_nice time. |
soft_interrupts |
Continous Counter |
Number of software interrupts since boot. |
steal |
Percentage |
Linux 2.6.11+; Percentage of time a virtual CPU waits for a real CPU while the hypervisor is servicing another virtual processor. |
system |
Percentage |
Percent time spent in kernel space. System CPU time is the time spent running code in the Operating System kernel. |
user |
Percentage |
Percent time spent in user space. User CPU time is the time spent on the processor running your program’s code (or code in libraries). |
Credits, License
Authors: Linuxfabrik GmbH, Zurich
License: The Unlicense, see LICENSE file.
Credits: psutil Documentation