mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-05 22:32:20 +01:00
app/vmstorage: add vm_free_disk_space_bytes
metric for monitoring the remaining disk space at -storageDataPath
This commit is contained in:
parent
8a02e01210
commit
f838cdc86e
@ -197,6 +197,10 @@ func registerStorageMetrics(strg *storage.Storage) {
|
|||||||
return &sm.IndexDBMetrics
|
return &sm.IndexDBMetrics
|
||||||
}
|
}
|
||||||
|
|
||||||
|
metrics.NewGauge(fmt.Sprintf(`vm_free_disk_space_bytes{path=%q}`, *DataPath), func() float64 {
|
||||||
|
return float64(fs.MustGetFreeSpace(*DataPath))
|
||||||
|
})
|
||||||
|
|
||||||
metrics.NewGauge(`vm_active_merges{type="storage/big"}`, func() float64 {
|
metrics.NewGauge(`vm_active_merges{type="storage/big"}`, func() float64 {
|
||||||
return float64(tm().ActiveBigMerges)
|
return float64(tm().ActiveBigMerges)
|
||||||
})
|
})
|
||||||
|
@ -864,10 +864,9 @@ The most interesting metrics are:
|
|||||||
* `vm_rows{type="indexdb"}` - the number of rows in inverted index. High value for this number usually mean high churn rate for time series.
|
* `vm_rows{type="indexdb"}` - the number of rows in inverted index. High value for this number usually mean high churn rate for time series.
|
||||||
* Sum of `vm_rows{type="storage/big"}` and `vm_rows{type="storage/small"}` - total number of `(timestamp, value)` data points
|
* Sum of `vm_rows{type="storage/big"}` and `vm_rows{type="storage/small"}` - total number of `(timestamp, value)` data points
|
||||||
in the database.
|
in the database.
|
||||||
* Sum of all the `vm_cache_size_bytes` metrics - the total size of all the caches in the database.
|
|
||||||
* `vm_allowed_memory_bytes` - the maximum allowed size for caches in the database. It is calculated as `system_memory * <-memory.allowedPercent> / 100`,
|
|
||||||
where `system_memory` is the amount of system memory and `-memory.allowedPercent` is the corresponding flag value.
|
|
||||||
* `vm_rows_inserted_total` - the total number of inserted rows since VictoriaMetrics start.
|
* `vm_rows_inserted_total` - the total number of inserted rows since VictoriaMetrics start.
|
||||||
|
* `vm_free_disk_space_bytes` - free space left at `-storageDataPath`.
|
||||||
|
* `sum(vm_data_size_bytes)` - the total data size on disk.
|
||||||
|
|
||||||
### Troubleshooting
|
### Troubleshooting
|
||||||
|
|
||||||
@ -883,7 +882,9 @@ The most interesting metrics are:
|
|||||||
|
|
||||||
* VictoriaMetrics requires free disk space for [merging data files to bigger ones](https://medium.com/@valyala/how-victoriametrics-makes-instant-snapshots-for-multi-terabyte-time-series-data-e1f3fb0e0282).
|
* VictoriaMetrics requires free disk space for [merging data files to bigger ones](https://medium.com/@valyala/how-victoriametrics-makes-instant-snapshots-for-multi-terabyte-time-series-data-e1f3fb0e0282).
|
||||||
It may slow down when there is no enough free space left. So make sure `-storageDataPath` directory
|
It may slow down when there is no enough free space left. So make sure `-storageDataPath` directory
|
||||||
has at least 20% of free space comparing to disk size.
|
has at least 20% of free space comparing to disk size. The remaining amount of free space
|
||||||
|
can be [monitored](#monitoring) via `vm_free_disk_space_bytes` metric. The total size of data
|
||||||
|
stored on the disk can be monitored via sum of `vm_data_size_bytes` metrics.
|
||||||
|
|
||||||
* If VictoriaMetrics doesn't work because of certain parts are corrupted due to disk errors,
|
* If VictoriaMetrics doesn't work because of certain parts are corrupted due to disk errors,
|
||||||
then just remove directories with broken parts. This will recover VictoriaMetrics at the cost
|
then just remove directories with broken parts. This will recover VictoriaMetrics at the cost
|
||||||
|
Loading…
Reference in New Issue
Block a user