tracker/stats/mem.go

84 lines
2.4 KiB
Go
Raw Normal View History

2014-07-23 23:08:06 +02:00
// Copyright 2014 The Chihaya Authors. All rights reserved.
// Use of this source code is governed by the BSD 2-Clause license,
// which can be found in the LICENSE file.
package stats
import (
"encoding/json"
"runtime"
)
// BasicMemStats includes a few of the fields from runtime.MemStats suitable for
// general logging.
type BasicMemStats struct {
// General statistics.
Alloc uint64 // bytes allocated and still in use
TotalAlloc uint64 // bytes allocated (even if freed)
2014-07-23 23:58:44 +02:00
Sys uint64 // bytes obtained from system (sum of XxxSys in runtime)
2014-07-23 23:08:06 +02:00
Lookups uint64 // number of pointer lookups
Mallocs uint64 // number of mallocs
Frees uint64 // number of frees
// Main allocation heap statistics.
HeapAlloc uint64 // bytes allocated and still in use
HeapSys uint64 // bytes obtained from system
HeapIdle uint64 // bytes in idle spans
HeapInuse uint64 // bytes in non-idle span
HeapReleased uint64 // bytes released to the OS
HeapObjects uint64 // total number of allocated objects
// Garbage collector statistics.
PauseTotalNs uint64
}
2014-07-23 23:25:01 +02:00
// MemStatsWrapper wraps runtime.MemStats with an optionally less verbose JSON
// representation. The JSON field names correspond exactly to the runtime field
// names to avoid reimplementing the entire struct.
2014-07-23 23:08:06 +02:00
type MemStatsWrapper struct {
basic *BasicMemStats
full *runtime.MemStats
verbose bool
}
func NewMemStatsWrapper(verbose bool) *MemStatsWrapper {
stats := &MemStatsWrapper{
verbose: verbose,
full: &runtime.MemStats{},
}
if !verbose {
stats.basic = &BasicMemStats{}
}
return stats
}
func (s *MemStatsWrapper) MarshalJSON() ([]byte, error) {
if s.verbose {
return json.Marshal(s.full)
} else {
return json.Marshal(s.basic)
}
}
2014-07-23 23:25:01 +02:00
// Update fetches the current memstats from runtime and resets the cache.
2014-07-23 23:08:06 +02:00
func (s *MemStatsWrapper) Update() {
runtime.ReadMemStats(s.full)
if !s.verbose {
// Gross, but any decent editor can generate this in a couple commands.
s.basic.Alloc = s.full.Alloc
s.basic.TotalAlloc = s.full.TotalAlloc
s.basic.Sys = s.full.Sys
s.basic.Lookups = s.full.Lookups
s.basic.Mallocs = s.full.Mallocs
s.basic.Frees = s.full.Frees
s.basic.HeapAlloc = s.full.HeapAlloc
s.basic.HeapSys = s.full.HeapSys
s.basic.HeapIdle = s.full.HeapIdle
s.basic.HeapInuse = s.full.HeapInuse
s.basic.HeapReleased = s.full.HeapReleased
s.basic.HeapObjects = s.full.HeapObjects
s.basic.PauseTotalNs = s.full.PauseTotalNs
}
}