Skip to main content

System statistics

Plugin: proc.plugin Module: /proc/stat

Overview

CPU utilization, states and frequencies and key Linux system performance metrics.

The /proc/stat file provides various types of system statistics:

  • The overall system CPU usage statistics
  • Per CPU core statistics
  • The total context switching of the system
  • The total number of processes running
  • The total CPU interrupts
  • The total CPU softirqs

The collector also reads:

  • /proc/schedstat for statistics about the process scheduler in the Linux kernel.
  • /sys/devices/system/cpu/[X]/thermal_throttle/core_throttle_count to get the count of thermal throttling events for a specific CPU core on Linux systems.
  • /sys/devices/system/cpu/[X]/thermal_throttle/package_throttle_count to get the count of thermal throttling events for a specific CPU package on a Linux system.
  • /sys/devices/system/cpu/[X]/cpufreq/scaling_cur_freq to get the current operating frequency of a specific CPU core.
  • /sys/devices/system/cpu/[X]/cpufreq/stats/time_in_state to get the amount of time the CPU has spent in each of its available frequency states.
  • /sys/devices/system/cpu/[X]/cpuidle/state[X]/name to get the names of the idle states for each CPU core in a Linux system.
  • /sys/devices/system/cpu/[X]/cpuidle/state[X]/time to get the total time each specific CPU core has spent in each idle state since the system was started.

This collector is only supported on the following platforms:

  • linux

This collector only supports collecting metrics from a single instance of this integration.

Default Behavior

Auto-Detection

The collector auto-detects all metrics. No configuration is needed.

Limits

The default configuration for this integration does not impose any limits on data collection.

Performance Impact

The collector disables cpu frequency and idle state monitoring when there are more than 128 CPU cores available.

Metrics

Metrics grouped by scope.

The scope defines the instance that the metric belongs to. An instance is uniquely identified by a set of labels.

Per System statistics instance

This scope has no labels.

Metrics:

MetricDimensionsUnit
system.cpuguest_nice, guest, steal, softirq, irq, user, system, nice, iowait, idlepercentage
system.intrinterruptsinterrupts/s
system.ctxtswitchescontext switches/s
system.forksstartedprocesses/s
system.processesrunning, blockedprocesses
cpu.core_throttlinga dimension per cpu coreevents/s
cpu.package_throttlinga dimension per packageevents/s
cpu.cpufreqa dimension per cpu coreMHz

Per cpu core

Labels:

LabelDescription
cpuTBD

Metrics:

MetricDimensionsUnit
cpu.cpuguest_nice, guest, steal, softirq, irq, user, system, nice, iowait, idlepercentage
cpuidle.cpu_cstate_residency_timea dimension per c-statepercentage

Alerts

The following alerts are available:

Alert nameOn metricDescription
10min_cpu_usage system.cpuaverage CPU utilization over the last 10 minutes (excluding iowait, nice and steal)
10min_cpu_iowait system.cpuaverage CPU iowait time over the last 10 minutes
20min_steal_cpu system.cpuaverage CPU steal time over the last 20 minutes

Setup

Prerequisites

No action required.

Configuration

File

The configuration file name for this integration is netdata.conf. Configuration for this specific integration is located in the plugin:proc:/proc/stat section within that file.

The file format is a modified INI syntax. The general structure is:

[section1]
option1 = some value
option2 = some other value

[section2]
option3 = some third value

You can edit the configuration file using the edit-config script from the Netdata config directory.

cd /etc/netdata 2>/dev/null || cd /opt/netdata/etc/netdata
sudo ./edit-config netdata.conf

Options

There are no configuration options.

Examples

There are no configuration examples.


Do you have any feedback for this page? If so, you can open a new issue on our netdata/learn repository.