Skip to content

Commit

Permalink
Check BSD's mib which accounts for swap size (prometheus#1149)
Browse files Browse the repository at this point in the history
* Change Dfly's CPU counting frequency, see: prometheus#1129

Signed-off-by: iori-yja <[email protected]>

* Convert Dfly's CPU unit into second

Signed-off-by: iori-yja <[email protected]>

* Check BSD's mib which accounts for swap size; see prometheus#1127

Signed-off-by: iori-yja <[email protected]>

* fix swap check code

Signed-off-by: iori-yja <[email protected]>
  • Loading branch information
iori-yja authored and discordianfish committed Nov 17, 2018
1 parent 3cf5b00 commit 17fee80
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 16 deletions.
19 changes: 4 additions & 15 deletions collector/cpu_dragonfly.go
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ import (
#include <stdio.h>
int
getCPUTimes(uint64_t **cputime, size_t *cpu_times_len, long *freq) {
getCPUTimes(uint64_t **cputime, size_t *cpu_times_len) {
size_t len;
// Get number of cpu cores.
Expand All @@ -44,15 +44,6 @@ getCPUTimes(uint64_t **cputime, size_t *cpu_times_len, long *freq) {
return -1;
}
// The bump on each statclock is
// ((cur_systimer - prev_systimer) * systimer_freq) >> 32
// where
// systimer_freq = sysctl kern.cputimer.freq
len = sizeof(*freq);
if (sysctlbyname("kern.cputimer.freq", freq, &len, NULL, 0)) {
return -1;
}
// Get the cpu times.
struct kinfo_cputime cp_t[ncpu];
bzero(cp_t, sizeof(struct kinfo_cputime)*ncpu);
Expand Down Expand Up @@ -103,18 +94,16 @@ func getDragonFlyCPUTimes() ([]float64, error) {
// CPUSTATES (number of CPUSTATES) is defined as 5U.
// States: CP_USER | CP_NICE | CP_SYS | CP_IDLE | CP_INTR
//
// Each value is a counter incremented at frequency
// kern.cputimer.freq
// Each value is in microseconds
//
// Look into sys/kern/kern_clock.c for details.

var (
cpuTimesC *C.uint64_t
cpuTimerFreq C.long
cpuTimesLength C.size_t
)

if C.getCPUTimes(&cpuTimesC, &cpuTimesLength, &cpuTimerFreq) == -1 {
if C.getCPUTimes(&cpuTimesC, &cpuTimesLength) == -1 {
return nil, errors.New("could not retrieve CPU times")
}
defer C.free(unsafe.Pointer(cpuTimesC))
Expand All @@ -123,7 +112,7 @@ func getDragonFlyCPUTimes() ([]float64, error) {

cpuTimes := make([]float64, cpuTimesLength)
for i, value := range cput {
cpuTimes[i] = float64(value) / float64(cpuTimerFreq)
cpuTimes[i] = float64(value) / float64(1000000)
}
return cpuTimes, nil
}
Expand Down
9 changes: 8 additions & 1 deletion collector/memory_bsd.go
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,13 @@ func NewMemoryCollector() (Collector, error) {
}
size := float64(tmp32)

mibSwapTotal := "vm.swap_total"
/* swap_total is FreeBSD specific. Fall back to Dfly specific mib if not present. */
_, err = unix.SysctlUint32(mibSwapTotal)
if err != nil {
mibSwapTotal = "vm.swap_size"
}

fromPage := func(v float64) float64 {
return v * size
}
Expand Down Expand Up @@ -98,7 +105,7 @@ func NewMemoryCollector() (Collector, error) {
{
name: "swap_size_bytes",
description: "Total swap memory size",
mib: "vm.swap_total",
mib: mibSwapTotal,
dataType: bsdSysctlTypeUint64,
},
// Descriptions via: top(1)
Expand Down

0 comments on commit 17fee80

Please sign in to comment.