Skip to main content

SoftIRQ statistics

Plugin: proc.plugin Module: /proc/softirqs

Overview

In the Linux kernel, handling of hardware interrupts is split into two halves: the top half and the bottom half. The top half is the routine that responds immediately to an interrupt, while the bottom half is deferred to be processed later.

Softirqs are a mechanism in the Linux kernel used to handle the bottom halves of interrupts, which can be deferred and processed later in a context where it's safe to enable interrupts.

The actual work of handling the interrupt is offloaded to a softirq and executed later when the system decides it's a good time to process them. This helps to keep the system responsive by not blocking the top half for too long, which could lead to missed interrupts.

Monitoring /proc/softirqs is useful for:

  • Performance tuning: A high rate of softirqs could indicate a performance issue. For instance, a high rate of network softirqs (NET_RX and NET_TX) could indicate a network performance issue.

  • Troubleshooting: If a system is behaving unexpectedly, checking the softirqs could provide clues about what is going on. For example, a sudden increase in block device softirqs (BLOCK) might indicate a problem with a disk.

  • Understanding system behavior: Knowing what types of softirqs are happening can help you understand what your system is doing, particularly in terms of how it's interacting with hardware and how it's handling interrupts.

This collector is supported on all platforms.

This collector supports collecting metrics from multiple instances of this integration, including remote instances.

Default Behavior

Auto-Detection

This integration doesn't support auto-detection.

Limits

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

Performance Impact

The default configuration for this integration is not expected to impose a significant performance impact on the system.

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 SoftIRQ statistics instance

This scope has no labels.

Metrics:

MetricDimensionsUnit
system.softirqsa dimension per softirqsoftirqs/s

Per cpu core

Labels:

LabelDescription
cpuTBD

Metrics:

MetricDimensionsUnit
cpu.softirqsa dimension per softirqsoftirqs/s

Alerts

There are no alerts configured by default for this integration.

Setup

Prerequisites

No action required.

Configuration

File

There is no configuration file.

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.