Merge remote-tracking branch 'origin/refactor_collectors' into refactor_collectors
commit
e1b5fa2aed
|
@ -18,9 +18,13 @@ package collector
|
|||
|
||||
import (
|
||||
"fmt"
|
||||
"strings"
|
||||
|
||||
"github.com/go-kit/log"
|
||||
"github.com/go-kit/log/level"
|
||||
"github.com/prometheus/client_golang/prometheus"
|
||||
|
||||
"golang.org/x/sys/unix"
|
||||
)
|
||||
|
||||
type zfsCollector struct {
|
||||
|
@ -33,7 +37,7 @@ const (
|
|||
)
|
||||
|
||||
func init() {
|
||||
registerCollector("zfs", defaultEnabled, NewZfsCollector)
|
||||
registerCollector(zfsCollectorSubsystem, defaultEnabled, NewZfsCollector)
|
||||
}
|
||||
|
||||
func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector, error) {
|
||||
|
@ -45,6 +49,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.abdstats.linear_cnt",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.CounterValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "abdstats_linear_data_bytes",
|
||||
|
@ -52,6 +57,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.abdstats.linear_data_size",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.GaugeValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "abdstats_scatter_chunk_waste_bytes",
|
||||
|
@ -59,6 +65,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.abdstats.scatter_chunk_waste",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.GaugeValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "abdstats_scatter_count_total",
|
||||
|
@ -66,6 +73,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.abdstats.scatter_cnt",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.CounterValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "abdstats_scatter_data_bytes",
|
||||
|
@ -73,6 +81,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.abdstats.scatter_data_size",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.GaugeValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "abdstats_struct_bytes",
|
||||
|
@ -80,6 +89,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.abdstats.struct_size",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.GaugeValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "arcstats_anon_bytes",
|
||||
|
@ -87,6 +97,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.arcstats.anon_size",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.GaugeValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "arcstats_c_bytes",
|
||||
|
@ -94,6 +105,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.arcstats.c",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.GaugeValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "arcstats_c_max_bytes",
|
||||
|
@ -101,6 +113,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.arcstats.c_max",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.GaugeValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "arcstats_c_min_bytes",
|
||||
|
@ -108,6 +121,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.arcstats.c_min",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.GaugeValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "arcstats_data_bytes",
|
||||
|
@ -115,6 +129,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.arcstats.data_size",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.GaugeValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "arcstats_demand_data_hits_total",
|
||||
|
@ -122,6 +137,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.arcstats.demand_data_hits",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.CounterValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "arcstats_demand_data_misses_total",
|
||||
|
@ -129,6 +145,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.arcstats.demand_data_misses",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.CounterValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "arcstats_demand_metadata_hits_total",
|
||||
|
@ -136,6 +153,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.arcstats.demand_metadata_hits",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.CounterValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "arcstats_demand_metadata_misses_total",
|
||||
|
@ -143,6 +161,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.arcstats.demand_metadata_misses",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.CounterValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "arcstats_hdr_bytes",
|
||||
|
@ -150,6 +169,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.arcstats.hdr_size",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.GaugeValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "arcstats_hits_total",
|
||||
|
@ -157,6 +177,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.arcstats.hits",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.CounterValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "arcstats_misses_total",
|
||||
|
@ -164,6 +185,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.arcstats.misses",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.CounterValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "arcstats_mfu_ghost_hits_total",
|
||||
|
@ -171,6 +193,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.arcstats.mfu_ghost_hits",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.CounterValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "arcstats_mfu_ghost_size",
|
||||
|
@ -178,6 +201,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.arcstats.mfu_ghost_size",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.GaugeValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "arcstats_mfu_bytes",
|
||||
|
@ -185,6 +209,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.arcstats.mfu_size",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.GaugeValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "arcstats_mru_ghost_hits_total",
|
||||
|
@ -192,6 +217,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.arcstats.mru_ghost_hits",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.CounterValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "arcstats_mru_ghost_bytes",
|
||||
|
@ -199,6 +225,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.arcstats.mru_ghost_size",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.GaugeValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "arcstats_mru_bytes",
|
||||
|
@ -206,6 +233,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.arcstats.mru_size",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.GaugeValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "arcstats_other_bytes",
|
||||
|
@ -213,13 +241,37 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.arcstats.other_size",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.GaugeValue,
|
||||
labels: nil,
|
||||
},
|
||||
// when FreeBSD 14.0+, `meta/pm/pd` install of `p`.
|
||||
{
|
||||
name: "arcstats_p_bytes",
|
||||
description: "ZFS ARC MRU target size",
|
||||
mib: "kstat.zfs.misc.arcstats.p",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.GaugeValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "arcstats_meta_bytes",
|
||||
description: "ZFS ARC metadata target frac ",
|
||||
mib: "kstat.zfs.misc.arcstats.meta",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.GaugeValue,
|
||||
},
|
||||
{
|
||||
name: "arcstats_pd_bytes",
|
||||
description: "ZFS ARC data MRU target frac",
|
||||
mib: "kstat.zfs.misc.arcstats.pd",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.GaugeValue,
|
||||
},
|
||||
{
|
||||
name: "arcstats_pm_bytes",
|
||||
description: "ZFS ARC meta MRU target frac",
|
||||
mib: "kstat.zfs.misc.arcstats.pm",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.GaugeValue,
|
||||
},
|
||||
{
|
||||
name: "arcstats_size_bytes",
|
||||
|
@ -227,6 +279,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.arcstats.size",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.GaugeValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "zfetchstats_hits_total",
|
||||
|
@ -234,6 +287,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.zfetchstats.hits",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.CounterValue,
|
||||
labels: nil,
|
||||
},
|
||||
{
|
||||
name: "zfetchstats_misses_total",
|
||||
|
@ -241,6 +295,7 @@ func NewZfsCollector(config *NodeCollectorConfig, logger log.Logger) (Collector,
|
|||
mib: "kstat.zfs.misc.zfetchstats.misses",
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.CounterValue,
|
||||
labels: nil,
|
||||
},
|
||||
},
|
||||
logger: logger,
|
||||
|
@ -251,7 +306,9 @@ func (c *zfsCollector) Update(ch chan<- prometheus.Metric) error {
|
|||
for _, m := range c.sysctls {
|
||||
v, err := m.Value()
|
||||
if err != nil {
|
||||
return fmt.Errorf("couldn't get sysctl: %w", err)
|
||||
// debug logging
|
||||
level.Debug(c.logger).Log("name", m.name, "couldn't get sysctl:", err)
|
||||
continue
|
||||
}
|
||||
|
||||
ch <- prometheus.MustNewConstMetric(
|
||||
|
@ -264,3 +321,42 @@ func (c *zfsCollector) Update(ch chan<- prometheus.Metric) error {
|
|||
|
||||
return nil
|
||||
}
|
||||
|
||||
func (c *zfsCollector) parseFreeBSDPoolObjsetStats() error {
|
||||
|
||||
sysCtlMetrics := []string{
|
||||
"nunlinked", "nunlinks", "nread", "reads", "nwritten", "writes",
|
||||
}
|
||||
zfsPoolMibPrefix := "kstat.zfs.pool.dataset"
|
||||
zfsDatasetNames := []string{}
|
||||
|
||||
zfsDatasets, err := unix.Sysctl(zfsPoolMibPrefix)
|
||||
if err != nil {
|
||||
return fmt.Errorf("couldn't get sysctl: %w", err)
|
||||
}
|
||||
|
||||
for dataset, _ := range zfsDatasets {
|
||||
if strings.HasSuffix(dataset, ".dataset_name") {
|
||||
zfsDatasetsNames = append(zfsDatasetsNames, strings.SplitAfter(dataset, ".")[3])
|
||||
}
|
||||
}
|
||||
|
||||
for _, zpoolDataset := range zfsDatasetsNames {
|
||||
zfsDatasetLabels := map[string]string{
|
||||
"dataset": zpoolDataset,
|
||||
"zpool": strings.SplitAfter(zpoolDataset, "/")[0],
|
||||
}
|
||||
for metric := range sysCtlMetrics {
|
||||
c.sysctls = append(c.sysctls, bsdSysctl{
|
||||
name: fmt.SprintF("node_zfs_zpool_dataset_%s", metric),
|
||||
description: fmt.SprintF("node_zfs_zpool_dataset_%s", metric),
|
||||
mib: fmt.Sprintf("%s.%s.%s", zfsPoolMibPrefix, poolObj, metric),
|
||||
dataType: bsdSysctlTypeUint64,
|
||||
valueType: prometheus.CounterValue,
|
||||
labels: zfsDatasetLabels,
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
|
6
go.mod
6
go.mod
|
@ -22,8 +22,8 @@ require (
|
|||
github.com/mdlayher/wifi v0.1.0
|
||||
github.com/opencontainers/selinux v1.11.0
|
||||
github.com/prometheus-community/go-runit v0.1.0
|
||||
github.com/prometheus/client_golang v1.16.0
|
||||
github.com/prometheus/client_model v0.4.0
|
||||
github.com/prometheus/client_golang v1.17.0
|
||||
github.com/prometheus/client_model v0.4.1-0.20230718164431-9a2bf3000d16
|
||||
github.com/prometheus/common v0.44.0
|
||||
github.com/prometheus/exporter-toolkit v0.10.0
|
||||
github.com/prometheus/procfs v0.11.1
|
||||
|
@ -58,6 +58,6 @@ require (
|
|||
golang.org/x/sync v0.3.0 // indirect
|
||||
golang.org/x/text v0.10.0 // indirect
|
||||
google.golang.org/appengine v1.6.7 // indirect
|
||||
google.golang.org/protobuf v1.30.0 // indirect
|
||||
google.golang.org/protobuf v1.31.0 // indirect
|
||||
gopkg.in/yaml.v2 v2.4.0 // indirect
|
||||
)
|
||||
|
|
12
go.sum
12
go.sum
|
@ -76,10 +76,10 @@ github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZb
|
|||
github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4=
|
||||
github.com/prometheus-community/go-runit v0.1.0 h1:uTWEj/Fn2RoLdfg/etSqwzgYNOYPrARx1BHUN052tGA=
|
||||
github.com/prometheus-community/go-runit v0.1.0/go.mod h1:AvJ9Jo3gAFu2lbM4+qfjdpq30FfiLDJZKbQ015u08IQ=
|
||||
github.com/prometheus/client_golang v1.16.0 h1:yk/hx9hDbrGHovbci4BY+pRMfSuuat626eFsHb7tmT8=
|
||||
github.com/prometheus/client_golang v1.16.0/go.mod h1:Zsulrv/L9oM40tJ7T815tM89lFEugiJ9HzIqaAx4LKc=
|
||||
github.com/prometheus/client_model v0.4.0 h1:5lQXD3cAg1OXBf4Wq03gTrXHeaV0TQvGfUooCfx1yqY=
|
||||
github.com/prometheus/client_model v0.4.0/go.mod h1:oMQmHW1/JoDwqLtg57MGgP/Fb1CJEYF2imWWhWtMkYU=
|
||||
github.com/prometheus/client_golang v1.17.0 h1:rl2sfwZMtSthVU752MqfjQozy7blglC+1SOtjMAMh+Q=
|
||||
github.com/prometheus/client_golang v1.17.0/go.mod h1:VeL+gMmOAxkS2IqfCq0ZmHSL+LjWfWDUmp1mBz9JgUY=
|
||||
github.com/prometheus/client_model v0.4.1-0.20230718164431-9a2bf3000d16 h1:v7DLqVdK4VrYkVD5diGdl4sxJurKJEMnODWRJlxV9oM=
|
||||
github.com/prometheus/client_model v0.4.1-0.20230718164431-9a2bf3000d16/go.mod h1:oMQmHW1/JoDwqLtg57MGgP/Fb1CJEYF2imWWhWtMkYU=
|
||||
github.com/prometheus/common v0.44.0 h1:+5BrQJwiBB9xsMygAB3TNvpQKOwlkc25LbISbrdOOfY=
|
||||
github.com/prometheus/common v0.44.0/go.mod h1:ofAIvZbQ1e/nugmZGz4/qCb9Ap1VoSTIO7x0VV9VvuY=
|
||||
github.com/prometheus/exporter-toolkit v0.10.0 h1:yOAzZTi4M22ZzVxD+fhy1URTuNRj/36uQJJ5S8IPza8=
|
||||
|
@ -167,8 +167,8 @@ google.golang.org/appengine v1.6.7 h1:FZR1q0exgwxzPzp/aF+VccGrSfxfPpkBqjIIEq3ru6
|
|||
google.golang.org/appengine v1.6.7/go.mod h1:8WjMMxjGQR8xUklV/ARdw2HLXBOI7O7uCIDZVag1xfc=
|
||||
google.golang.org/protobuf v1.26.0-rc.1/go.mod h1:jlhhOSvTdKEhbULTjvd4ARK9grFBp09yW+WbY/TyQbw=
|
||||
google.golang.org/protobuf v1.26.0/go.mod h1:9q0QmTI4eRPtz6boOQmLYwt+qCgq0jsYwAQnmE0givc=
|
||||
google.golang.org/protobuf v1.30.0 h1:kPPoIgf3TsEvrm0PFe15JQ+570QVxYzEvvHqChK+cng=
|
||||
google.golang.org/protobuf v1.30.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
|
||||
google.golang.org/protobuf v1.31.0 h1:g0LDEJHgrBl9N9r17Ru3sqWhkIx2NB67okBHPwC7hs8=
|
||||
google.golang.org/protobuf v1.31.0/go.mod h1:HV8QOd/L58Z+nl8r43ehVNZIU/HEI6OcFqwMG9pJV4I=
|
||||
gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0=
|
||||
gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c h1:Hei/4ADfdWqJk1ZMxUNpqntNwaWcugrBjAiHlqqRiVk=
|
||||
gopkg.in/yaml.v1 v1.0.0-20140924161607-9f9df34309c0/go.mod h1:WDnlLJ4WF5VGsH/HVa3CI79GS0ol3YnhVnKP89i0kNg=
|
||||
|
|
Loading…
Reference in New Issue