mirror of
https://github.com/prometheus/node_exporter.git
synced 2025-01-13 06:48:05 -08:00
Correctly cast Darwin memory info (#1060)
* Correctly cast Darwin memory info * Cast stats to float64 before doing math on them to avoid integer wrapping. * Remove invalid `_total` suffix from gauge values. * Handle counters in `meminfo.go`. Signed-off-by: Ben Kochie <superq@gmail.com>
This commit is contained in:
parent
05e55bddad
commit
ebdd524123
|
@ -1,6 +1,6 @@
|
||||||
## master / unreleased
|
## master / unreleased
|
||||||
|
|
||||||
**Breaking changes**
|
### **Breaking changes**
|
||||||
|
|
||||||
supvervisord collector reports "start_time_seconds" rather than "uptime"
|
supvervisord collector reports "start_time_seconds" rather than "uptime"
|
||||||
|
|
||||||
|
@ -8,6 +8,9 @@ The wifi collector is disabled by default due to suspected caching issues and go
|
||||||
* https://github.com/prometheus/node_exporter/issues/870
|
* https://github.com/prometheus/node_exporter/issues/870
|
||||||
* https://github.com/prometheus/node_exporter/issues/1008
|
* https://github.com/prometheus/node_exporter/issues/1008
|
||||||
|
|
||||||
|
Darwin meminfo metrics have been renamed to match Prometheus conventions. #1060
|
||||||
|
|
||||||
|
### Changes
|
||||||
* [CHANGE] Filter out non-installed units when collecting all systemd units #1011
|
* [CHANGE] Filter out non-installed units when collecting all systemd units #1011
|
||||||
* [CHANGE] `service_restart_total` and `socket_refused_connections_total` will not be reported if you're running an older version of systemd
|
* [CHANGE] `service_restart_total` and `socket_refused_connections_total` will not be reported if you're running an older version of systemd
|
||||||
* [FEATURE] Collect NRefused property for systemd socket units (available as of systemd v239)
|
* [FEATURE] Collect NRefused property for systemd socket units (available as of systemd v239)
|
||||||
|
@ -19,6 +22,7 @@ The wifi collector is disabled by default due to suspected caching issues and go
|
||||||
* [BUGFIX] Fix goroutine leak in supervisord collector
|
* [BUGFIX] Fix goroutine leak in supervisord collector
|
||||||
* [BUGFIX] Systemd units will not be ignored if you're running older versions of systemd #1039
|
* [BUGFIX] Systemd units will not be ignored if you're running older versions of systemd #1039
|
||||||
* [BUGFIX] Handle vanishing PIDs #1043
|
* [BUGFIX] Handle vanishing PIDs #1043
|
||||||
|
* [BUGFIX] Correctly cast Darwin memory info #1060
|
||||||
|
|
||||||
## 0.16.0 / 2018-05-15
|
## 0.16.0 / 2018-05-15
|
||||||
|
|
||||||
|
|
|
@ -18,6 +18,7 @@ package collector
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"strings"
|
||||||
|
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
"github.com/prometheus/common/log"
|
"github.com/prometheus/common/log"
|
||||||
|
@ -41,19 +42,25 @@ func NewMeminfoCollector() (Collector, error) {
|
||||||
// Update calls (*meminfoCollector).getMemInfo to get the platform specific
|
// Update calls (*meminfoCollector).getMemInfo to get the platform specific
|
||||||
// memory metrics.
|
// memory metrics.
|
||||||
func (c *meminfoCollector) Update(ch chan<- prometheus.Metric) error {
|
func (c *meminfoCollector) Update(ch chan<- prometheus.Metric) error {
|
||||||
|
var metricType prometheus.ValueType
|
||||||
memInfo, err := c.getMemInfo()
|
memInfo, err := c.getMemInfo()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("couldn't get meminfo: %s", err)
|
return fmt.Errorf("couldn't get meminfo: %s", err)
|
||||||
}
|
}
|
||||||
log.Debugf("Set node_mem: %#v", memInfo)
|
log.Debugf("Set node_mem: %#v", memInfo)
|
||||||
for k, v := range memInfo {
|
for k, v := range memInfo {
|
||||||
|
if strings.HasSuffix(k, "_total") {
|
||||||
|
metricType = prometheus.CounterValue
|
||||||
|
} else {
|
||||||
|
metricType = prometheus.GaugeValue
|
||||||
|
}
|
||||||
ch <- prometheus.MustNewConstMetric(
|
ch <- prometheus.MustNewConstMetric(
|
||||||
prometheus.NewDesc(
|
prometheus.NewDesc(
|
||||||
prometheus.BuildFQName(namespace, memInfoSubsystem, k),
|
prometheus.BuildFQName(namespace, memInfoSubsystem, k),
|
||||||
fmt.Sprintf("Memory information field %s.", k),
|
fmt.Sprintf("Memory information field %s.", k),
|
||||||
nil, nil,
|
nil, nil,
|
||||||
),
|
),
|
||||||
prometheus.GaugeValue, v,
|
metricType, v,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
|
|
|
@ -46,14 +46,14 @@ func (c *meminfoCollector) getMemInfo() (map[string]float64, error) {
|
||||||
// Syscall removes terminating NUL which we need to cast to uint64
|
// Syscall removes terminating NUL which we need to cast to uint64
|
||||||
total := binary.LittleEndian.Uint64([]byte(totalb + "\x00"))
|
total := binary.LittleEndian.Uint64([]byte(totalb + "\x00"))
|
||||||
|
|
||||||
ps := C.natural_t(syscall.Getpagesize())
|
ps := float64(C.natural_t(syscall.Getpagesize()))
|
||||||
return map[string]float64{
|
return map[string]float64{
|
||||||
"active_bytes_total": float64(ps * vmstat.active_count),
|
"active_bytes": ps * float64(vmstat.active_count),
|
||||||
"inactive_bytes_total": float64(ps * vmstat.inactive_count),
|
"inactive_bytes": ps * float64(vmstat.inactive_count),
|
||||||
"wired_bytes_total": float64(ps * vmstat.wire_count),
|
"wired_bytes": ps * float64(vmstat.wire_count),
|
||||||
"free_bytes_total": float64(ps * vmstat.free_count),
|
"free_bytes": ps * float64(vmstat.free_count),
|
||||||
"swapped_in_pages_total": float64(ps * vmstat.pageins),
|
"swapped_in_bytes_total": ps * float64(vmstat.pageins),
|
||||||
"swapped_out_pages_total": float64(ps * vmstat.pageouts),
|
"swapped_out_bytes_total": ps * float64(vmstat.pageouts),
|
||||||
"bytes_total": float64(total),
|
"total_bytes": float64(total),
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue