This file is indexed.

/usr/share/check_mk/checks-man/diskstat is in check-mk-server 1.2.2p3-1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
title: Monitor disk throughput on Linux
agents: linux
author: Mathias Kettner <mk@mathias-kettner.de>
license: GPL
distribution: check_mk
description:

 This check measures the throughput of block devices (disks) on Linux
 hosts. You can either have a single check for every single disk
 (which is the default) or a summary check summing up the throughput
 of all disks.

 For legacy reasons it is also possible (but not advisable) to have all disks
 summarized but with a separate check for read and write (this is how this
 check worked up to version 1.1.10).

 The check also gives info on the IO latency and IOPS (unmerged) aquired
 from the kernels information in /proc.

 You can apply separate warning and critical levels for the read
 and write throughput. Optionally you can have the check compute
 average values on a configurable time period and have the levels
 applied on the average instead of the current values. This makes
 it possible to ignore short "peaks" and only trigger and longer
 phases of high disk activity.

 Averaging is not applied to IO latency calculations.

 The check has to provide many ways of configuration for legacy reasons.
 We strongly recommend you switch to the rule-based configuration, which
 handles anything you want it to.

item:
 Either {"SUMMARY"} for a summarized check of all disks or the
 name of the disk device, e.g. {"sda"}. Additionally also one service
 per logical volume defined in Linux LVM and Veritas VxVM on Linux.

 In order to support configurations
 up to version 1.1.10 also the items {"read"} and {"write"} are supported.


examples:
 # switch inventory behaviour to 1.1.10 mode
 diskstat_inventory_mode = "legacy"

 # alternative: create one check for all disks
 diskstat_inventory_mode = "summary"

 # Set default levels for diskstat
 diskstat_default_levels = {
   "read" :    (10, 20),   # level for read MB/sec
   "write" :   (20, 40),   # level for write MB/sec
   "average" : 15,         # averaging in minutes
 }

 # Alternative: just enable averaging over 10 minutes,
 # do not apply levels:
 diskstat_default_levels = {
     "average" : 15
 }

 # Settings for certain hosts:
 check_parameters += [
   ( {"write" : (20, 50), "average" : 10 }, [ "oracle" ], ALL_HOSTS, [ "Disk IO" ])
 ]

 # New way:

 # Enable and configure the inventory behaviour based with rule-based settings
 diskstat_inventory_mode = "rule"
 diskstat_inventory += [
  ( ['summary', 'lvm', 'vxvm'], [], ALL_HOSTS ),
 ]

 # Then configure levels for 50/90MB/s read IO over 10 Minutes and a bit less for
 # writes. Next put levels on IO latency exceeding 80ms / 160ms.
 checkgroup_parameters['disk_io'] += [
   ( {'read': (50.0, 90.0), 'write': (40.0, 60.0), 'average': 10, 'latency_perfdata': True, 'latency': (80.0, 160.0)}, [], ALL_HOSTS, ALL_SERVICES ),
 ]




perfdata:
  The disk throughput for read and write in bytes per second. If averaging
  is turned on, then two additional values are sent: the averaged read and
  write throughput.

  The IO latency is returned if {"latency_perfdata"} is set to True

  In the legacy mode only one variable: the throughput since the last check
  in in bytes(!) per second, either for read or for write.

inventory:
  The inventory is configured via {diskstat_inventory_mode}. If this is set
  to {"single"} (the default), then one check will be created for each
  disk. If it is set to {"summary"} then only one service per host will be
  created that has at least one hard disk. If set to {"legacy"} then a
  separate check for read and write will be created (deprecated).

[parameters]
"read": The levels to be applied to the read throughput. It this entry is
 {None} or missing in the dictionary, then no levels are applied. This is
 the defaut. The values are in MB per second. Setting {"read"} to {(20, 40)}
 will warn if 20 MB/s is exceeded and make the check critical at 40 MB/s.
 If averaging is turned on, then the levels are applied to the averaged
 values!

"write": The levels for the write throughput.

"average": If this is not {None}, it will be interpreted as a time range
 in minutes to do averaging over. Set this to {15} in order to have
 the levels applied to a 15-minute average instead of the current
 values (approx.). Turning the average on will also create two additional
 performance values. Make sure that your graphing tool is setup to
 a changing number of variables.

[configuration]
diskstat_defaul_levels(dict): The default parameter used for inventorized
                             checks. This is preset to the empty dictionary.
                              That means that no averaging is done and no
                              levels are applied.

diskstat_inventory_mode(string): By default this is now set to {"rule"} for
 fine-grained configuration of blockdevices to monitor.
 The actual rule is defined in {"diststat_inventory"}.

 The following older style parameters are also still available and mapped
 to rules internally. Either {"single"} for one service per disk
 or {"summary"} for the throughput of all disks summed up in one service.
 Also possible is {"legacy"} for the old style mode (see above). Default
 is {"summary"}.


diskstat_inventory(list): This is a list of block device types to track.
 Possible values are {"summary"}, which creates a summary item showing the IO
 rate of all disks, but not other block devices.
 If you want statistics for every single disk, you can use {"phyiscal"}.
 Enabling {"lvm"} will generate one item for each LVM volume, including snapshot
 volumes.
 Enabling {"vxvm"} will generate one item for each volume managed by VxVM,
 including layered volumes.