mirror of
https://github.com/prometheus-community/windows_exporter
synced 2025-01-02 03:42:05 +00:00
07fff6afc2
* Added physical_disk collector. Signed-off-by: Rob Scheepens <rob.scheepens@nutanix.com> Signed-off-by: Brantley West <brantley@nutanix.com> * exporter.go: Added physical_disk to defaultCollectors Signed-off-by: Rob Scheepens <rob.scheepens@nutanix.com> Signed-off-by: Brantley West <brantley@nutanix.com> * Fix test cases for physicaldisk metrics Signed-off-by: Rob Scheepens <rob.scheepens@nutanix.com> Signed-off-by: Brantley West <brantley@nutanix.com> * physical_disk.go: cleanup gofmt error Signed-off-by: Brantley West <brantley@nutanix.com> * physical_disk.go: populate physical disk 'number' label Signed-off-by: Brantley West <brantley@nutanix.com> * Added docs/collector.physical_disk.md. Signed-off-by: Rob Scheepens <rob.scheepens@nutanix.com> * physical_disk.go: change 'number' label to 'disk' to match node_exporter label Signed-off-by: Brantley West <brantley@nutanix.com> * physical_disk.go: adopt github.com/go-kit/log Signed-off-by: Brantley West <brantley@nutanix.com> * physical_disk.go: adopt include/exclude disk list Signed-off-by: Brantley West <brantley@nutanix.com> * fix: Add init config for physical_disk collector Signed-off-by: Ben Reedy <breed808@breed808.com> * chore: gofmt physical_disk collector Signed-off-by: Ben Reedy <breed808@breed808.com> --------- Signed-off-by: Rob Scheepens <rob.scheepens@nutanix.com> Signed-off-by: Brantley West <brantley@nutanix.com> Signed-off-by: Ben Reedy <breed808@breed808.com> Co-authored-by: Brantley West <brantley@nutanix.com> Co-authored-by: Ben Reedy <breed808@breed808.com>
81 lines
3.5 KiB
Markdown
81 lines
3.5 KiB
Markdown
# physical_disk collector
|
|
|
|
The physical_disk collector exposes metrics about physical disks
|
|
|
|
|||
|
|
-|-
|
|
Metric name prefix | `physical_disk`
|
|
Data source | Perflib
|
|
Counters | `physicalDisk` ([`Win32_PerfRawData_PerfDisk_physicalDisk`](https://msdn.microsoft.com/en-us/windows/hardware/aa394307(v=vs.71)))
|
|
Enabled by default? | Yes
|
|
|
|
## Flags
|
|
|
|
### `--collector.physical_disk.disk-include`
|
|
|
|
If given, a disk needs to match the include regexp in order for the corresponding disk metrics to be reported
|
|
|
|
### `--collector.physical_disk.disk-exclude`
|
|
|
|
If given, a disk needs to *not* match the exclude regexp in order for the corresponding disk metrics to be reported
|
|
|
|
## Metrics
|
|
|
|
Name | Description | Type | Labels
|
|
-----|-------------|------|-------
|
|
`requests_queued` | Number of requests outstanding on the disk at the time the performance data is collected | gauge | `disk`
|
|
`read_bytes_total` | Rate at which bytes are transferred from the disk during read operations | counter | `disk`
|
|
`reads_total` | Rate of read operations on the disk | counter | `disk`
|
|
`write_bytes_total` | Rate at which bytes are transferred to the disk during write operations | counter | `disk`
|
|
`writes_total` | Rate of write operations on the disk | counter | `disk`
|
|
`read_seconds_total` | Seconds the disk was busy servicing read requests | counter | `disk`
|
|
`write_seconds_total` | Seconds the disk was busy servicing write requests | counter | `disk`
|
|
`free_bytes` | Unused space of the disk in bytes (not real time, updates every 10-15 min) | gauge | `disk`
|
|
`size_bytes` | Total size of the disk in bytes (not real time, updates every 10-15 min) | gauge | `disk`
|
|
`idle_seconds_total` | Seconds the disk was idle (not servicing read/write requests) | counter | `disk`
|
|
`split_ios_total` | Number of I/Os to the disk split into multiple I/Os | counter | `disk`
|
|
|
|
### Warning about size metrics
|
|
The `free_bytes` and `size_bytes` metrics are not updated in real time and might have a delay of 10-15min.
|
|
This is the same behavior as the windows performance counters.
|
|
|
|
### Example metric
|
|
Query the rate of write operations to a disk
|
|
```
|
|
rate(windows_physical_disk_read_bytes_total{instance="localhost", disk=~"0"}[2m])
|
|
```
|
|
|
|
## Useful queries
|
|
Calculate rate of total IOPS for disk
|
|
```
|
|
rate(windows_physical_disk_reads_total{instance="localhost", disk=~"0"}[2m]) + rate(windows_physical_disk_writes_total{instance="localhost", disk=~"0"}[2m])
|
|
```
|
|
|
|
## Alerting examples
|
|
**prometheus.rules**
|
|
```yaml
|
|
groups:
|
|
- name: Windows Disk Alerts
|
|
rules:
|
|
|
|
# Sends an alert when disk space usage is above 95%
|
|
- alert: DiskSpaceUsage
|
|
expr: 100.0 - 100 * (windows_physical_disk_free_bytes / windows_physical_disk_size_bytes) > 95
|
|
for: 10m
|
|
labels:
|
|
severity: high
|
|
annotations:
|
|
summary: "Disk Space Usage (instance {{ $labels.instance }})"
|
|
description: "Disk Space on Drive is used more than 95%\n VALUE = {{ $value }}\n LABELS: {{ $labels }}"
|
|
|
|
# Alerts on disks with over 85% space usage predicted to fill within the next four days
|
|
- alert: DiskFilling
|
|
expr: 100 * (windows_physical_disk_free_bytes / windows_physical_disk_size_bytes) < 15 and predict_linear(windows_physical_disk_free_bytes[6h], 4 * 24 * 3600) < 0
|
|
for: 10m
|
|
labels:
|
|
severity: warning
|
|
annotations:
|
|
summary: "Disk full in four days (instance {{ $labels.instance }})"
|
|
description: "{{ $labels.disk }} is expected to fill up within four days. Currently {{ $value | humanize }}% is available.\n VALUE = {{ $value }}\n LABELS: {{ $labels }}"
|
|
```
|