mirror of
https://github.com/prometheus/node_exporter.git
synced 2025-01-20 07:19:01 +01:00
collector/cpu: split cpu freq metrics into separate collector (#1253)
The cpu frequency information is not always needed and/or available. This change allows the cpu frequency metrics to be enabled/disabled separately from the other cpu metrics, and also prevents a frequency metric failure (such as a parse error) from failing the main cpu collector. Fixes #1241 Signed-off-by: Paul Gier <pgier@redhat.com>
This commit is contained in:
parent
f028b81615
commit
cc847f2f44
@ -21,6 +21,7 @@
|
|||||||
* [CHANGE] Add separate cpufreq and scaling metrics #1248
|
* [CHANGE] Add separate cpufreq and scaling metrics #1248
|
||||||
* [CHANGE] Several systemd metrics have been turned off by default to improve performance #1254
|
* [CHANGE] Several systemd metrics have been turned off by default to improve performance #1254
|
||||||
* [CHANGE] Expand systemd collector blacklist #1255
|
* [CHANGE] Expand systemd collector blacklist #1255
|
||||||
|
* [CHANGE] Split cpufreq metrics into a separate collector #1253
|
||||||
* [ENHANCEMENT] Add Infiniband counters #1120
|
* [ENHANCEMENT] Add Infiniband counters #1120
|
||||||
* [ENHANCEMENT] Move network_up labels into new metric network_info #1236
|
* [ENHANCEMENT] Move network_up labels into new metric network_info #1236
|
||||||
* [FEATURE] Add a flag to disable exporter metrics #1148
|
* [FEATURE] Add a flag to disable exporter metrics #1148
|
||||||
|
@ -32,6 +32,7 @@ bonding | Exposes the number of configured and active slaves of Linux bonding in
|
|||||||
boottime | Exposes system boot time derived from the `kern.boottime` sysctl. | Darwin, Dragonfly, FreeBSD, NetBSD, OpenBSD, Solaris
|
boottime | Exposes system boot time derived from the `kern.boottime` sysctl. | Darwin, Dragonfly, FreeBSD, NetBSD, OpenBSD, Solaris
|
||||||
conntrack | Shows conntrack statistics (does nothing if no `/proc/sys/net/netfilter/` present). | Linux
|
conntrack | Shows conntrack statistics (does nothing if no `/proc/sys/net/netfilter/` present). | Linux
|
||||||
cpu | Exposes CPU statistics | Darwin, Dragonfly, FreeBSD, Linux, Solaris
|
cpu | Exposes CPU statistics | Darwin, Dragonfly, FreeBSD, Linux, Solaris
|
||||||
|
cpufreq | Exposes CPU frequency statistics | Linux, Solaris
|
||||||
diskstats | Exposes disk I/O statistics. | Darwin, Linux, OpenBSD
|
diskstats | Exposes disk I/O statistics. | Darwin, Linux, OpenBSD
|
||||||
edac | Exposes error detection and correction statistics. | Linux
|
edac | Exposes error detection and correction statistics. | Linux
|
||||||
entropy | Exposes available entropy. | Linux
|
entropy | Exposes available entropy. | Linux
|
||||||
|
@ -23,18 +23,11 @@ import (
|
|||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
"github.com/prometheus/common/log"
|
"github.com/prometheus/common/log"
|
||||||
"github.com/prometheus/procfs"
|
"github.com/prometheus/procfs"
|
||||||
"github.com/prometheus/procfs/sysfs"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type cpuCollector struct {
|
type cpuCollector struct {
|
||||||
cpu *prometheus.Desc
|
cpu *prometheus.Desc
|
||||||
cpuGuest *prometheus.Desc
|
cpuGuest *prometheus.Desc
|
||||||
cpuFreq *prometheus.Desc
|
|
||||||
cpuFreqMin *prometheus.Desc
|
|
||||||
cpuFreqMax *prometheus.Desc
|
|
||||||
scalingFreq *prometheus.Desc
|
|
||||||
scalingFreqMin *prometheus.Desc
|
|
||||||
scalingFreqMax *prometheus.Desc
|
|
||||||
cpuCoreThrottle *prometheus.Desc
|
cpuCoreThrottle *prometheus.Desc
|
||||||
cpuPackageThrottle *prometheus.Desc
|
cpuPackageThrottle *prometheus.Desc
|
||||||
}
|
}
|
||||||
@ -52,36 +45,6 @@ func NewCPUCollector() (Collector, error) {
|
|||||||
"Seconds the cpus spent in guests (VMs) for each mode.",
|
"Seconds the cpus spent in guests (VMs) for each mode.",
|
||||||
[]string{"cpu", "mode"}, nil,
|
[]string{"cpu", "mode"}, nil,
|
||||||
),
|
),
|
||||||
cpuFreq: prometheus.NewDesc(
|
|
||||||
prometheus.BuildFQName(namespace, cpuCollectorSubsystem, "frequency_hertz"),
|
|
||||||
"Current cpu thread frequency in hertz.",
|
|
||||||
[]string{"cpu"}, nil,
|
|
||||||
),
|
|
||||||
cpuFreqMin: prometheus.NewDesc(
|
|
||||||
prometheus.BuildFQName(namespace, cpuCollectorSubsystem, "frequency_min_hertz"),
|
|
||||||
"Minimum cpu thread frequency in hertz.",
|
|
||||||
[]string{"cpu"}, nil,
|
|
||||||
),
|
|
||||||
cpuFreqMax: prometheus.NewDesc(
|
|
||||||
prometheus.BuildFQName(namespace, cpuCollectorSubsystem, "frequency_max_hertz"),
|
|
||||||
"Maximum cpu thread frequency in hertz.",
|
|
||||||
[]string{"cpu"}, nil,
|
|
||||||
),
|
|
||||||
scalingFreq: prometheus.NewDesc(
|
|
||||||
prometheus.BuildFQName(namespace, cpuCollectorSubsystem, "scaling_frequency_hertz"),
|
|
||||||
"Current scaled cpu thread frequency in hertz.",
|
|
||||||
[]string{"cpu"}, nil,
|
|
||||||
),
|
|
||||||
scalingFreqMin: prometheus.NewDesc(
|
|
||||||
prometheus.BuildFQName(namespace, cpuCollectorSubsystem, "scaling_frequency_min_hrts"),
|
|
||||||
"Minimum scaled cpu thread frequency in hertz.",
|
|
||||||
[]string{"cpu"}, nil,
|
|
||||||
),
|
|
||||||
scalingFreqMax: prometheus.NewDesc(
|
|
||||||
prometheus.BuildFQName(namespace, cpuCollectorSubsystem, "scaling_frequency_max_hrts"),
|
|
||||||
"Maximum scaled cpu thread frequency in hertz.",
|
|
||||||
[]string{"cpu"}, nil,
|
|
||||||
),
|
|
||||||
cpuCoreThrottle: prometheus.NewDesc(
|
cpuCoreThrottle: prometheus.NewDesc(
|
||||||
prometheus.BuildFQName(namespace, cpuCollectorSubsystem, "core_throttles_total"),
|
prometheus.BuildFQName(namespace, cpuCollectorSubsystem, "core_throttles_total"),
|
||||||
"Number of times this cpu core has been throttled.",
|
"Number of times this cpu core has been throttled.",
|
||||||
@ -100,82 +63,12 @@ func (c *cpuCollector) Update(ch chan<- prometheus.Metric) error {
|
|||||||
if err := c.updateStat(ch); err != nil {
|
if err := c.updateStat(ch); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
if err := c.updateCPUfreq(ch); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
if err := c.updateThermalThrottle(ch); err != nil {
|
if err := c.updateThermalThrottle(ch); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// updateCPUfreq reads /sys/devices/system/cpu/cpu* and expose cpu frequency statistics.
|
|
||||||
func (c *cpuCollector) updateCPUfreq(ch chan<- prometheus.Metric) error {
|
|
||||||
fs, err := sysfs.NewFS(*sysPath)
|
|
||||||
if err != nil {
|
|
||||||
return fmt.Errorf("failed to open sysfs: %v", err)
|
|
||||||
}
|
|
||||||
|
|
||||||
cpuFreqs, err := fs.NewSystemCpufreq()
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
// sysfs cpufreq values are kHz, thus multiply by 1000 to export base units (hz).
|
|
||||||
// See https://www.kernel.org/doc/Documentation/cpu-freq/user-guide.txt
|
|
||||||
for _, stats := range cpuFreqs {
|
|
||||||
if stats.CpuinfoCurrentFrequency != nil {
|
|
||||||
ch <- prometheus.MustNewConstMetric(
|
|
||||||
c.cpuFreq,
|
|
||||||
prometheus.GaugeValue,
|
|
||||||
float64(*stats.CpuinfoCurrentFrequency)*1000.0,
|
|
||||||
stats.Name,
|
|
||||||
)
|
|
||||||
}
|
|
||||||
if stats.CpuinfoMinimumFrequency != nil {
|
|
||||||
ch <- prometheus.MustNewConstMetric(
|
|
||||||
c.cpuFreqMin,
|
|
||||||
prometheus.GaugeValue,
|
|
||||||
float64(*stats.CpuinfoMinimumFrequency)*1000.0,
|
|
||||||
stats.Name,
|
|
||||||
)
|
|
||||||
}
|
|
||||||
if stats.CpuinfoMaximumFrequency != nil {
|
|
||||||
ch <- prometheus.MustNewConstMetric(
|
|
||||||
c.cpuFreqMax,
|
|
||||||
prometheus.GaugeValue,
|
|
||||||
float64(*stats.CpuinfoMaximumFrequency)*1000.0,
|
|
||||||
stats.Name,
|
|
||||||
)
|
|
||||||
}
|
|
||||||
if stats.ScalingCurrentFrequency != nil {
|
|
||||||
ch <- prometheus.MustNewConstMetric(
|
|
||||||
c.scalingFreq,
|
|
||||||
prometheus.GaugeValue,
|
|
||||||
float64(*stats.ScalingCurrentFrequency)*1000.0,
|
|
||||||
stats.Name,
|
|
||||||
)
|
|
||||||
}
|
|
||||||
if stats.ScalingMinimumFrequency != nil {
|
|
||||||
ch <- prometheus.MustNewConstMetric(
|
|
||||||
c.scalingFreqMin,
|
|
||||||
prometheus.GaugeValue,
|
|
||||||
float64(*stats.ScalingMinimumFrequency)*1000.0,
|
|
||||||
stats.Name,
|
|
||||||
)
|
|
||||||
}
|
|
||||||
if stats.ScalingMaximumFrequency != nil {
|
|
||||||
ch <- prometheus.MustNewConstMetric(
|
|
||||||
c.scalingFreqMax,
|
|
||||||
prometheus.GaugeValue,
|
|
||||||
float64(*stats.ScalingMaximumFrequency)*1000.0,
|
|
||||||
stats.Name,
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
// updateThermalThrottle reads /sys/devices/system/cpu/cpu* and expose thermal throttle statistics.
|
// updateThermalThrottle reads /sys/devices/system/cpu/cpu* and expose thermal throttle statistics.
|
||||||
func (c *cpuCollector) updateThermalThrottle(ch chan<- prometheus.Metric) error {
|
func (c *cpuCollector) updateThermalThrottle(ch chan<- prometheus.Metric) error {
|
||||||
cpus, err := filepath.Glob(sysFilePath("devices/system/cpu/cpu[0-9]*"))
|
cpus, err := filepath.Glob(sysFilePath("devices/system/cpu/cpu[0-9]*"))
|
||||||
|
@ -17,20 +17,17 @@
|
|||||||
package collector
|
package collector
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
|
||||||
"strconv"
|
"strconv"
|
||||||
|
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
"github.com/siebenmann/go-kstat"
|
kstat "github.com/siebenmann/go-kstat"
|
||||||
)
|
)
|
||||||
|
|
||||||
// #include <unistd.h>
|
// #include <unistd.h>
|
||||||
import "C"
|
import "C"
|
||||||
|
|
||||||
type cpuCollector struct {
|
type cpuCollector struct {
|
||||||
cpu typedDesc
|
cpu typedDesc
|
||||||
cpuFreq *prometheus.Desc
|
|
||||||
cpuFreqMax *prometheus.Desc
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
@ -40,30 +37,10 @@ func init() {
|
|||||||
func NewCpuCollector() (Collector, error) {
|
func NewCpuCollector() (Collector, error) {
|
||||||
return &cpuCollector{
|
return &cpuCollector{
|
||||||
cpu: typedDesc{nodeCPUSecondsDesc, prometheus.CounterValue},
|
cpu: typedDesc{nodeCPUSecondsDesc, prometheus.CounterValue},
|
||||||
cpuFreq: prometheus.NewDesc(
|
|
||||||
prometheus.BuildFQName(namespace, cpuCollectorSubsystem, "frequency_hertz"),
|
|
||||||
"Current cpu thread frequency in hertz.",
|
|
||||||
[]string{"cpu"}, nil,
|
|
||||||
),
|
|
||||||
cpuFreqMax: prometheus.NewDesc(
|
|
||||||
prometheus.BuildFQName(namespace, cpuCollectorSubsystem, "frequency_max_hertz"),
|
|
||||||
"Maximum cpu thread frequency in hertz.",
|
|
||||||
[]string{"cpu"}, nil,
|
|
||||||
),
|
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *cpuCollector) Update(ch chan<- prometheus.Metric) error {
|
func (c *cpuCollector) Update(ch chan<- prometheus.Metric) error {
|
||||||
if err := c.updateCPUstats(ch); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
if err := c.updateCPUfreq(ch); err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (c *cpuCollector) updateCPUstats(ch chan<- prometheus.Metric) error {
|
|
||||||
ncpus := C.sysconf(C._SC_NPROCESSORS_ONLN)
|
ncpus := C.sysconf(C._SC_NPROCESSORS_ONLN)
|
||||||
|
|
||||||
tok, err := kstat.Open()
|
tok, err := kstat.Open()
|
||||||
@ -95,46 +72,3 @@ func (c *cpuCollector) updateCPUstats(ch chan<- prometheus.Metric) error {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *cpuCollector) updateCPUfreq(ch chan<- prometheus.Metric) error {
|
|
||||||
ncpus := C.sysconf(C._SC_NPROCESSORS_ONLN)
|
|
||||||
|
|
||||||
tok, err := kstat.Open()
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
defer tok.Close()
|
|
||||||
|
|
||||||
for cpu := 0; cpu < int(ncpus); cpu++ {
|
|
||||||
ksCPUInfo, err := tok.Lookup("cpu_info", cpu, fmt.Sprintf("cpu_info%d", cpu))
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
cpuFreqV, err := ksCPUInfo.GetNamed("current_clock_Hz")
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
cpuFreqMaxV, err := ksCPUInfo.GetNamed("clock_MHz")
|
|
||||||
if err != nil {
|
|
||||||
return err
|
|
||||||
}
|
|
||||||
|
|
||||||
lcpu := strconv.Itoa(cpu)
|
|
||||||
ch <- prometheus.MustNewConstMetric(
|
|
||||||
c.cpuFreq,
|
|
||||||
prometheus.GaugeValue,
|
|
||||||
float64(cpuFreqV.UintVal),
|
|
||||||
lcpu,
|
|
||||||
)
|
|
||||||
// Multiply by 1e+6 to convert MHz to Hz.
|
|
||||||
ch <- prometheus.MustNewConstMetric(
|
|
||||||
c.cpuFreqMax,
|
|
||||||
prometheus.GaugeValue,
|
|
||||||
float64(cpuFreqMaxV.IntVal)*1e+6,
|
|
||||||
lcpu,
|
|
||||||
)
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
139
collector/cpufreq_linux.go
Normal file
139
collector/cpufreq_linux.go
Normal file
@ -0,0 +1,139 @@
|
|||||||
|
// Copyright 2019 The Prometheus Authors
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
|
||||||
|
// +build !nocpu
|
||||||
|
|
||||||
|
package collector
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
|
||||||
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
|
"github.com/prometheus/procfs/sysfs"
|
||||||
|
)
|
||||||
|
|
||||||
|
type cpuFreqCollector struct {
|
||||||
|
cpuFreq *prometheus.Desc
|
||||||
|
cpuFreqMin *prometheus.Desc
|
||||||
|
cpuFreqMax *prometheus.Desc
|
||||||
|
scalingFreq *prometheus.Desc
|
||||||
|
scalingFreqMin *prometheus.Desc
|
||||||
|
scalingFreqMax *prometheus.Desc
|
||||||
|
}
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
registerCollector("cpufreq", defaultEnabled, NewCPUFreqCollector)
|
||||||
|
}
|
||||||
|
|
||||||
|
// NewCPUFreqCollector returns a new Collector exposing kernel/system statistics.
|
||||||
|
func NewCPUFreqCollector() (Collector, error) {
|
||||||
|
return &cpuFreqCollector{
|
||||||
|
cpuFreq: prometheus.NewDesc(
|
||||||
|
prometheus.BuildFQName(namespace, cpuCollectorSubsystem, "frequency_hertz"),
|
||||||
|
"Current cpu thread frequency in hertz.",
|
||||||
|
[]string{"cpu"}, nil,
|
||||||
|
),
|
||||||
|
cpuFreqMin: prometheus.NewDesc(
|
||||||
|
prometheus.BuildFQName(namespace, cpuCollectorSubsystem, "frequency_min_hertz"),
|
||||||
|
"Minimum cpu thread frequency in hertz.",
|
||||||
|
[]string{"cpu"}, nil,
|
||||||
|
),
|
||||||
|
cpuFreqMax: prometheus.NewDesc(
|
||||||
|
prometheus.BuildFQName(namespace, cpuCollectorSubsystem, "frequency_max_hertz"),
|
||||||
|
"Maximum cpu thread frequency in hertz.",
|
||||||
|
[]string{"cpu"}, nil,
|
||||||
|
),
|
||||||
|
scalingFreq: prometheus.NewDesc(
|
||||||
|
prometheus.BuildFQName(namespace, cpuCollectorSubsystem, "scaling_frequency_hertz"),
|
||||||
|
"Current scaled cpu thread frequency in hertz.",
|
||||||
|
[]string{"cpu"}, nil,
|
||||||
|
),
|
||||||
|
scalingFreqMin: prometheus.NewDesc(
|
||||||
|
prometheus.BuildFQName(namespace, cpuCollectorSubsystem, "scaling_frequency_min_hrts"),
|
||||||
|
"Minimum scaled cpu thread frequency in hertz.",
|
||||||
|
[]string{"cpu"}, nil,
|
||||||
|
),
|
||||||
|
scalingFreqMax: prometheus.NewDesc(
|
||||||
|
prometheus.BuildFQName(namespace, cpuCollectorSubsystem, "scaling_frequency_max_hrts"),
|
||||||
|
"Maximum scaled cpu thread frequency in hertz.",
|
||||||
|
[]string{"cpu"}, nil,
|
||||||
|
),
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Update implements Collector and exposes cpu related metrics from /proc/stat and /sys/.../cpu/.
|
||||||
|
func (c *cpuFreqCollector) Update(ch chan<- prometheus.Metric) error {
|
||||||
|
fs, err := sysfs.NewFS(*sysPath)
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("failed to open sysfs: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
cpuFreqs, err := fs.NewSystemCpufreq()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
// sysfs cpufreq values are kHz, thus multiply by 1000 to export base units (hz).
|
||||||
|
// See https://www.kernel.org/doc/Documentation/cpu-freq/user-guide.txt
|
||||||
|
for _, stats := range cpuFreqs {
|
||||||
|
if stats.CpuinfoCurrentFrequency != nil {
|
||||||
|
ch <- prometheus.MustNewConstMetric(
|
||||||
|
c.cpuFreq,
|
||||||
|
prometheus.GaugeValue,
|
||||||
|
float64(*stats.CpuinfoCurrentFrequency)*1000.0,
|
||||||
|
stats.Name,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
if stats.CpuinfoMinimumFrequency != nil {
|
||||||
|
ch <- prometheus.MustNewConstMetric(
|
||||||
|
c.cpuFreqMin,
|
||||||
|
prometheus.GaugeValue,
|
||||||
|
float64(*stats.CpuinfoMinimumFrequency)*1000.0,
|
||||||
|
stats.Name,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
if stats.CpuinfoMaximumFrequency != nil {
|
||||||
|
ch <- prometheus.MustNewConstMetric(
|
||||||
|
c.cpuFreqMax,
|
||||||
|
prometheus.GaugeValue,
|
||||||
|
float64(*stats.CpuinfoMaximumFrequency)*1000.0,
|
||||||
|
stats.Name,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
if stats.ScalingCurrentFrequency != nil {
|
||||||
|
ch <- prometheus.MustNewConstMetric(
|
||||||
|
c.scalingFreq,
|
||||||
|
prometheus.GaugeValue,
|
||||||
|
float64(*stats.ScalingCurrentFrequency)*1000.0,
|
||||||
|
stats.Name,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
if stats.ScalingMinimumFrequency != nil {
|
||||||
|
ch <- prometheus.MustNewConstMetric(
|
||||||
|
c.scalingFreqMin,
|
||||||
|
prometheus.GaugeValue,
|
||||||
|
float64(*stats.ScalingMinimumFrequency)*1000.0,
|
||||||
|
stats.Name,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
if stats.ScalingMaximumFrequency != nil {
|
||||||
|
ch <- prometheus.MustNewConstMetric(
|
||||||
|
c.scalingFreqMax,
|
||||||
|
prometheus.GaugeValue,
|
||||||
|
float64(*stats.ScalingMaximumFrequency)*1000.0,
|
||||||
|
stats.Name,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
95
collector/cpufreq_solaris.go
Normal file
95
collector/cpufreq_solaris.go
Normal file
@ -0,0 +1,95 @@
|
|||||||
|
// Copyright 2019 The Prometheus Authors
|
||||||
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
// you may not use this file except in compliance with the License.
|
||||||
|
// You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software
|
||||||
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
// See the License for the specific language governing permissions and
|
||||||
|
// limitations under the License.
|
||||||
|
|
||||||
|
// +build solaris
|
||||||
|
// +build !nocpu
|
||||||
|
|
||||||
|
package collector
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"strconv"
|
||||||
|
|
||||||
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
|
kstat "github.com/siebenmann/go-kstat"
|
||||||
|
)
|
||||||
|
|
||||||
|
// #include <unistd.h>
|
||||||
|
import "C"
|
||||||
|
|
||||||
|
type cpuFreqCollector struct {
|
||||||
|
cpuFreq *prometheus.Desc
|
||||||
|
cpuFreqMax *prometheus.Desc
|
||||||
|
}
|
||||||
|
|
||||||
|
func init() {
|
||||||
|
registerCollector("cpufreq", defaultEnabled, NewCpuFreqCollector)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewFreqCpuCollector() (Collector, error) {
|
||||||
|
return &cpuFreqCollector{
|
||||||
|
cpuFreq: prometheus.NewDesc(
|
||||||
|
prometheus.BuildFQName(namespace, cpuCollectorSubsystem, "frequency_hertz"),
|
||||||
|
"Current cpu thread frequency in hertz.",
|
||||||
|
[]string{"cpu"}, nil,
|
||||||
|
),
|
||||||
|
cpuFreqMax: prometheus.NewDesc(
|
||||||
|
prometheus.BuildFQName(namespace, cpuCollectorSubsystem, "frequency_max_hertz"),
|
||||||
|
"Maximum cpu thread frequency in hertz.",
|
||||||
|
[]string{"cpu"}, nil,
|
||||||
|
),
|
||||||
|
}, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *cpuCollector) Update(ch chan<- prometheus.Metric) error {
|
||||||
|
ncpus := C.sysconf(C._SC_NPROCESSORS_ONLN)
|
||||||
|
|
||||||
|
tok, err := kstat.Open()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
defer tok.Close()
|
||||||
|
|
||||||
|
for cpu := 0; cpu < int(ncpus); cpu++ {
|
||||||
|
ksCPUInfo, err := tok.Lookup("cpu_info", cpu, fmt.Sprintf("cpu_info%d", cpu))
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
cpuFreqV, err := ksCPUInfo.GetNamed("current_clock_Hz")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
cpuFreqMaxV, err := ksCPUInfo.GetNamed("clock_MHz")
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
lcpu := strconv.Itoa(cpu)
|
||||||
|
ch <- prometheus.MustNewConstMetric(
|
||||||
|
c.cpuFreq,
|
||||||
|
prometheus.GaugeValue,
|
||||||
|
float64(cpuFreqV.UintVal),
|
||||||
|
lcpu,
|
||||||
|
)
|
||||||
|
// Multiply by 1e+6 to convert MHz to Hz.
|
||||||
|
ch <- prometheus.MustNewConstMetric(
|
||||||
|
c.cpuFreqMax,
|
||||||
|
prometheus.GaugeValue,
|
||||||
|
float64(cpuFreqMaxV.IntVal)*1e+6,
|
||||||
|
lcpu,
|
||||||
|
)
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
@ -2340,6 +2340,7 @@ node_scrape_collector_success{collector="bonding"} 1
|
|||||||
node_scrape_collector_success{collector="buddyinfo"} 1
|
node_scrape_collector_success{collector="buddyinfo"} 1
|
||||||
node_scrape_collector_success{collector="conntrack"} 1
|
node_scrape_collector_success{collector="conntrack"} 1
|
||||||
node_scrape_collector_success{collector="cpu"} 1
|
node_scrape_collector_success{collector="cpu"} 1
|
||||||
|
node_scrape_collector_success{collector="cpufreq"} 1
|
||||||
node_scrape_collector_success{collector="diskstats"} 1
|
node_scrape_collector_success{collector="diskstats"} 1
|
||||||
node_scrape_collector_success{collector="drbd"} 1
|
node_scrape_collector_success{collector="drbd"} 1
|
||||||
node_scrape_collector_success{collector="edac"} 1
|
node_scrape_collector_success{collector="edac"} 1
|
||||||
|
@ -2340,6 +2340,7 @@ node_scrape_collector_success{collector="bonding"} 1
|
|||||||
node_scrape_collector_success{collector="buddyinfo"} 1
|
node_scrape_collector_success{collector="buddyinfo"} 1
|
||||||
node_scrape_collector_success{collector="conntrack"} 1
|
node_scrape_collector_success{collector="conntrack"} 1
|
||||||
node_scrape_collector_success{collector="cpu"} 1
|
node_scrape_collector_success{collector="cpu"} 1
|
||||||
|
node_scrape_collector_success{collector="cpufreq"} 1
|
||||||
node_scrape_collector_success{collector="diskstats"} 1
|
node_scrape_collector_success{collector="diskstats"} 1
|
||||||
node_scrape_collector_success{collector="drbd"} 1
|
node_scrape_collector_success{collector="drbd"} 1
|
||||||
node_scrape_collector_success{collector="edac"} 1
|
node_scrape_collector_success{collector="edac"} 1
|
||||||
|
@ -8,6 +8,7 @@ enabled_collectors=$(cat << COLLECTORS
|
|||||||
buddyinfo
|
buddyinfo
|
||||||
conntrack
|
conntrack
|
||||||
cpu
|
cpu
|
||||||
|
cpufreq
|
||||||
diskstats
|
diskstats
|
||||||
drbd
|
drbd
|
||||||
edac
|
edac
|
||||||
|
Loading…
Reference in New Issue
Block a user