---
title: Telegraf Documentation
description: Telegraf plugin for collecting metrics from Interrupts
url: https://docs.influxdata.com/telegraf/v1/input-plugins/interrupts/
estimated_tokens: 1367
product: Telegraf
version: v1
---

-   Telegraf v1.3.0+

# Interrupts Input Plugin

This plugin gathers metrics about IRQs from interrupts (`/proc/interrupts`) and soft-interrupts (`/proc/softirqs`).

**Introduced in:** Telegraf v1.3.0 **Tags:** system **OS support:** all

## Global configuration options

Plugins support additional global and plugin configuration settings for tasks such as modifying metrics, tags, and fields, creating aliases, and configuring plugin ordering. See [CONFIGURATION.md](/telegraf/v1/configuration/#plugins) for more details.

## Configuration

```toml
# This plugin gathers interrupts data from /proc/interrupts and /proc/softirqs.
[[inputs.interrupts]]
  ## When set to true, cpu metrics are tagged with the cpu.  Otherwise cpu is
  ## stored as a field.
  ##
  ## The default is false for backwards compatibility, and will be changed to
  ## true in a future version.  It is recommended to set to true on new
  ## deployments.
  # cpu_as_tag = false

  ## To filter which IRQs to collect, make use of tagpass / tagdrop:
  # [inputs.interrupts.tagdrop]
  #   irq = [ "NET_RX", "TASKLET" ]
```

## Metrics

There are two styles depending on the value of `cpu_as_tag`.

With `cpu_as_tag = false`:

-   interrupts
    
    -   tags:
        -   irq (IRQ name)
        -   type
        -   device (name of the device that is located at the IRQ)
        -   cpu
    -   fields:
        -   cpu (int, number of interrupts per cpu)
        -   total (int, total number of interrupts)
-   soft\_interrupts
    
    -   tags:
        -   irq (IRQ name)
        -   type
        -   device (name of the device that is located at the IRQ)
        -   cpu
    -   fields:
        -   cpu (int, number of interrupts per cpu)
        -   total (int, total number of interrupts)

With `cpu_as_tag = true`:

-   interrupts
    
    -   tags:
        -   irq (IRQ name)
        -   type
        -   device (name of the device that is located at the IRQ)
        -   cpu
    -   fields:
        -   count (int, number of interrupts)
-   soft\_interrupts
    
    -   tags:
        -   irq (IRQ name)
        -   type
        -   device (name of the device that is located at the IRQ)
        -   cpu
    -   fields:
        -   count (int, number of interrupts)

## Example Output

With `cpu_as_tag = false`:

```text
interrupts,irq=0,type=IO-APIC,device=2-edge\ timer,cpu=cpu0 count=23i 1489346531000000000
interrupts,irq=1,type=IO-APIC,device=1-edge\ i8042,cpu=cpu0 count=9i 1489346531000000000
interrupts,irq=30,type=PCI-MSI,device=65537-edge\ virtio1-input.0,cpu=cpu1 count=1i 1489346531000000000
soft_interrupts,irq=NET_RX,cpu=cpu0 count=280879i 1489346531000000000
```

With `cpu_as_tag = true`:

```text
interrupts,cpu=cpu6,irq=PIW,type=Posted-interrupt\ wakeup\ event count=0i 1543539773000000000
interrupts,cpu=cpu7,irq=PIW,type=Posted-interrupt\ wakeup\ event count=0i 1543539773000000000
soft_interrupts,cpu=cpu0,irq=HI count=246441i 1543539773000000000
soft_interrupts,cpu=cpu1,irq=HI count=159154i 1543539773000000000
```

#### Related

-   [Configure plugins](/telegraf/v1/configure_plugins/)
-   [Interrupts Plugin Source](https://github.com/influxdata/telegraf/tree/v1.38.4/plugins/inputs/interrupts/README.md)
