mirror of
https://github.com/zrepl/zrepl.git
synced 2025-01-24 23:30:06 +01:00
54 lines
1.8 KiB
Go
54 lines
1.8 KiB
Go
package zfs
|
|
|
|
import "github.com/prometheus/client_golang/prometheus"
|
|
|
|
var prom struct {
|
|
ZFSListFilesystemVersionDuration *prometheus.HistogramVec
|
|
ZFSSnapshotDuration *prometheus.HistogramVec
|
|
ZFSBookmarkDuration *prometheus.HistogramVec
|
|
ZFSDestroyDuration *prometheus.HistogramVec
|
|
}
|
|
|
|
func init() {
|
|
prom.ZFSListFilesystemVersionDuration = prometheus.NewHistogramVec(prometheus.HistogramOpts{
|
|
Namespace: "zrepl",
|
|
Subsystem: "zfs",
|
|
Name: "list_filesystem_versions_duration",
|
|
Help: "Seconds it took for listing the versions of a given filesystem",
|
|
}, []string{"filesystem"})
|
|
prom.ZFSSnapshotDuration = prometheus.NewHistogramVec(prometheus.HistogramOpts{
|
|
Namespace: "zrepl",
|
|
Subsystem: "zfs",
|
|
Name: "snapshot_duration",
|
|
Help: "Seconds it took to create a snapshot a given filesystem",
|
|
}, []string{"filesystem"})
|
|
prom.ZFSBookmarkDuration = prometheus.NewHistogramVec(prometheus.HistogramOpts{
|
|
Namespace: "zrepl",
|
|
Subsystem: "zfs",
|
|
Name: "bookmark_duration",
|
|
Help: "Duration it took to bookmark a given snapshot",
|
|
}, []string{"filesystem"})
|
|
prom.ZFSDestroyDuration = prometheus.NewHistogramVec(prometheus.HistogramOpts{
|
|
Namespace: "zrepl",
|
|
Subsystem: "zfs",
|
|
Name: "destroy_duration",
|
|
Help: "Duration it took to destroy a dataset",
|
|
}, []string{"dataset_type", "filesystem"})
|
|
}
|
|
|
|
func PrometheusRegister(registry prometheus.Registerer) error {
|
|
if err := registry.Register(prom.ZFSListFilesystemVersionDuration); err != nil {
|
|
return err
|
|
}
|
|
if err := registry.Register(prom.ZFSBookmarkDuration); err != nil {
|
|
return err
|
|
}
|
|
if err := registry.Register(prom.ZFSSnapshotDuration); err != nil {
|
|
return err
|
|
}
|
|
if err := registry.Register(prom.ZFSDestroyDuration); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
}
|