2016-03-10 20:40:03 +08:00
# Kernel Input Plugin
This plugin is only available on Linux.
The kernel plugin gathers info about the kernel that doesn't fit into other
2022-06-08 05:37:08 +08:00
plugins. In general, it is the statistics available in `/proc/stat` that are not
covered by other plugins as well as the value of
2024-01-06 05:33:00 +08:00
`/proc/sys/kernel/random/entropy_avail` and optionally, Kernel Samepage Merging
and Pressure Stall Information.
2016-03-10 20:40:03 +08:00
2024-01-06 05:33:00 +08:00
The metrics are documented in `man 5 proc` under the `/proc/stat` section, as
well as `man 4 random` under the `/proc interfaces` section
(for `entropy_avail` ).
2016-03-10 20:40:03 +08:00
2021-11-25 03:18:53 +08:00
```text
2018-01-06 06:54:29 +08:00
/proc/sys/kernel/random/entropy_avail
Contains the value of available entropy
2016-03-10 20:40:03 +08:00
/proc/stat
kernel/system statistics. Varies with architecture. Common entries include:
page 5741 1808
The number of pages the system paged in and the number that were paged out (from disk).
swap 1 0
The number of swap pages that have been brought in and out.
intr 1462898
This line shows counts of interrupts serviced since boot time, for each of
the possible system interrupts. The first column is the total of all
interrupts serviced; each subsequent column is the total for a particular interrupt.
ctxt 115315
The number of context switches that the system underwent.
btime 769041601
boot time, in seconds since the Epoch, 1970-01-01 00:00:00 +0000 (UTC).
processes 86031
Number of forks since boot.
```
2023-11-29 21:47:39 +08:00
Kernel Samepage Merging is generally documented in [kernel documentation][1] and
2024-01-06 05:33:00 +08:00
the available metrics exposed via sysfs are documented in [admin guide][2].
Pressure Stall Information is exposed through `/proc/pressure` and is documented
in [kernel documentation][3]. Kernel version 4.20 or later is required.
Examples of PSI:
```shell
# /proc/pressure/cpu
some avg10=1.53 avg60=1.87 avg300=1.73 total=1088168194
# /proc/pressure/memory
some avg10=0.00 avg60=0.00 avg300=0.00 total=3463792
full avg10=0.00 avg60=0.00 avg300=0.00 total=1429641
# /proc/pressure/io
some avg10=0.00 avg60=0.00 avg300=0.00 total=68568296
full avg10=0.00 avg60=0.00 avg300=0.00 total=54982338
```
2023-08-10 04:43:14 +08:00
[1]: https://www.kernel.org/doc/html/latest/mm/ksm.html
[2]: https://www.kernel.org/doc/html/latest/admin-guide/mm/ksm.html#ksm-daemon-sysfs-interface
2024-01-06 05:33:00 +08:00
[3]: https://www.kernel.org/doc/html/latest/accounting/psi.html
2023-08-10 04:43:14 +08:00
2022-10-27 03:58:36 +08:00
## Global configuration options <!-- @/docs/includes/plugin_config.md -->
In addition to the plugin-specific configuration settings, plugins support
additional global and plugin configuration settings. These settings are used to
modify metrics, tags, and field or create aliases and configure ordering, etc.
See the [CONFIGURATION.md][CONFIGURATION.md] for more details.
2023-01-12 23:55:21 +08:00
[CONFIGURATION.md]: ../../../docs/CONFIGURATION.md#plugins
2022-10-27 03:58:36 +08:00
2021-11-25 03:18:53 +08:00
## Configuration
2016-03-10 20:40:03 +08:00
2022-05-24 21:49:47 +08:00
```toml @sample .conf
2023-08-10 04:43:14 +08:00
# Plugin to collect various Linux kernel statistics.
2023-03-06 19:18:43 +08:00
# This plugin ONLY supports Linux
2016-03-10 20:40:03 +08:00
[[inputs.kernel]]
2023-08-10 04:43:14 +08:00
## Additional gather options
## Possible options include:
## * ksm - kernel same-page merging
2024-01-06 05:33:00 +08:00
## * psi - pressure stall information
2023-08-10 04:43:14 +08:00
# collect = []
2016-03-10 20:40:03 +08:00
```
2023-02-09 18:04:41 +08:00
## Metrics
2016-03-10 20:40:03 +08:00
- kernel
2021-11-25 03:18:53 +08:00
- boot_time (integer, seconds since epoch, `btime` )
- context_switches (integer, `ctxt` )
- disk_pages_in (integer, `page (0)` )
- disk_pages_out (integer, `page (1)` )
- interrupts (integer, `intr` )
- processes_forked (integer, `processes` )
- entropy_avail (integer, `entropy_available` )
2023-08-10 04:43:14 +08:00
- ksm_full_scans (integer, how many times all mergeable areas have been scanned, `full_scans` )
- ksm_max_page_sharing (integer, maximum sharing allowed for each KSM page, `max_page_sharing` )
- ksm_merge_across_nodes (integer, whether pages should be merged across NUMA nodes, `merge_across_nodes` )
- ksm_pages_shared (integer, how many shared pages are being used, `pages_shared` )
- ksm_pages_sharing (integer,how many more sites are sharing them , `pages_sharing` )
- ksm_pages_to_scan (integer, how many pages to scan before ksmd goes to sleep, `pages_to_scan` )
- ksm_pages_unshared (integer, how many pages unique but repeatedly checked for merging, `pages_unshared` )
- ksm_pages_volatile (integer, how many pages changing too fast to be placed in a tree, `pages_volatile` )
- ksm_run (integer, whether ksm is running or not, `run` )
- ksm_sleep_millisecs (integer, how many milliseconds ksmd should sleep between scans, `sleep_millisecs` )
- ksm_stable_node_chains (integer, the number of KSM pages that hit the max_page_sharing limit, `stable_node_chains` )
- ksm_stable_node_chains_prune_millisecs (integer, how frequently KSM checks the metadata of the pages that hit the deduplication limit, `stable_node_chains_prune_millisecs` )
- ksm_stable_node_dups (integer, number of duplicated KSM pages, `stable_node_dups` )
- ksm_use_zero_pages (integer, whether empty pages should be treated specially, `use_zero_pages` )
2016-03-10 20:40:03 +08:00
2024-01-06 05:33:00 +08:00
- pressure (if `psi` is included in `collect` )
- tags:
- resource: cpu, memory, or io
- type: some or full
- floating-point fields: avg10, avg60, avg300
- integer fields: total
2021-11-25 03:18:53 +08:00
## Example Output
2016-03-10 20:40:03 +08:00
2024-01-06 05:33:00 +08:00
Default config:
2023-04-04 19:43:49 +08:00
```text
2023-08-10 04:43:14 +08:00
kernel boot_time=1690487872i,context_switches=321398652i,entropy_avail=256i,interrupts=141868628i,processes_forked=946492i 1691339564000000000
2024-01-06 05:33:00 +08:00
```
If `ksm` is included in `collect` :
2023-08-10 04:43:14 +08:00
2024-01-06 05:33:00 +08:00
```text
2023-08-10 04:43:14 +08:00
kernel boot_time=1690487872i,context_switches=321252729i,entropy_avail=256i,interrupts=141783427i,ksm_full_scans=0i,ksm_max_page_sharing=256i,ksm_merge_across_nodes=1i,ksm_pages_shared=0i,ksm_pages_sharing=0i,ksm_pages_to_scan=100i,ksm_pages_unshared=0i,ksm_pages_volatile=0i,ksm_run=0i,ksm_sleep_millisecs=20i,ksm_stable_node_chains=0i,ksm_stable_node_chains_prune_millisecs=2000i,ksm_stable_node_dups=0i,ksm_use_zero_pages=0i,processes_forked=946467i 1691339522000000000
2024-01-06 05:33:00 +08:00
```
2023-08-10 04:43:14 +08:00
2024-01-06 05:33:00 +08:00
If `psi` is included in `collect` :
```text
pressure,resource=cpu,type=some avg10=1.53,avg60=1.87,avg300=1.73 1700000000000000000
pressure,resource=memory,type=some avg10=0.00,avg60=0.00,avg300=0.00 1700000000000000000
pressure,resource=memory,type=full avg10=0.00,avg60=0.00,avg300=0.00 1700000000000000000
pressure,resource=io,type=some avg10=0.0,avg60=0.0,avg300=0.0 1700000000000000000
pressure,resource=io,type=full avg10=0.0,avg60=0.0,avg300=0.0 1700000000000000000
pressure,resource=cpu,type=some total=1088168194i 1700000000000000000
pressure,resource=memory,type=some total=3463792i 1700000000000000000
pressure,resource=memory,type=full total=1429641i 1700000000000000000
pressure,resource=io,type=some total=68568296i 1700000000000000000
pressure,resource=io,type=full total=54982338i 1700000000000000000
2016-03-10 20:40:03 +08:00
```
2024-01-06 05:33:00 +08:00
Note that the combination for `resource=cpu,type=full` is omitted because it is
always zero.