mirror of
https://github.com/status-im/consul.git
synced 2025-01-12 23:05:28 +00:00
8c684db488
* agent/debug: add package for debugging, host info * api: add v1/agent/host endpoint * agent: add v1/agent/host endpoint * command/debug: implementation of static capture * command/debug: tests and only configured targets * agent/debug: add basic test for host metrics * command/debug: add methods for dynamic data capture * api: add debug/pprof endpoints * command/debug: add pprof * command/debug: timing, wg, logs to disk * vendor: add gopsutil/disk * command/debug: add a usage section * website: add docs for consul debug * agent/host: require operator:read * api/host: improve docs and no retry timing * command/debug: fail on extra arguments * command/debug: fixup file permissions to 0644 * command/debug: remove server flags * command/debug: improve clarity of usage section * api/debug: add Trace for profiling, fix profile * command/debug: capture profile and trace at the same time * command/debug: add index document * command/debug: use "clusters" in place of members * command/debug: remove address in output * command/debug: improve comment on metrics sleep * command/debug: clarify usage * agent: always register pprof handlers and protect This will allow us to avoid a restart of a target agent for profiling by always registering the pprof handlers. Given this is a potentially sensitive path, it is protected with an operator:read ACL and enable debug being set to true on the target agent. enable_debug still requires a restart. If ACLs are disabled, enable_debug is sufficient. * command/debug: use trace.out instead of .prof More in line with golang docs. * agent: fix comment wording * agent: wrap table driven tests in t.run()
60 lines
1.3 KiB
Go
60 lines
1.3 KiB
Go
package debug
|
|
|
|
import (
|
|
"time"
|
|
|
|
"github.com/shirou/gopsutil/cpu"
|
|
"github.com/shirou/gopsutil/disk"
|
|
"github.com/shirou/gopsutil/host"
|
|
"github.com/shirou/gopsutil/mem"
|
|
)
|
|
|
|
const (
|
|
// DiskUsagePath is the path to check usage of the disk.
|
|
// Must be a filessytem path such as "/", not device file path like "/dev/vda1"
|
|
DiskUsagePath = "/"
|
|
)
|
|
|
|
// HostInfo includes information about resources on the host as well as
|
|
// collection time and
|
|
type HostInfo struct {
|
|
Memory *mem.VirtualMemoryStat
|
|
CPU []cpu.InfoStat
|
|
Host *host.InfoStat
|
|
Disk *disk.UsageStat
|
|
CollectionTime int64
|
|
Errors []error
|
|
}
|
|
|
|
// CollectHostInfo queries the host system and returns HostInfo. Any
|
|
// errors encountered will be returned in HostInfo.Errors
|
|
func CollectHostInfo() *HostInfo {
|
|
info := &HostInfo{CollectionTime: time.Now().UTC().UnixNano()}
|
|
|
|
if h, err := host.Info(); err != nil {
|
|
info.Errors = append(info.Errors, err)
|
|
} else {
|
|
info.Host = h
|
|
}
|
|
|
|
if v, err := mem.VirtualMemory(); err != nil {
|
|
info.Errors = append(info.Errors, err)
|
|
} else {
|
|
info.Memory = v
|
|
}
|
|
|
|
if d, err := disk.Usage(DiskUsagePath); err != nil {
|
|
info.Errors = append(info.Errors, err)
|
|
} else {
|
|
info.Disk = d
|
|
}
|
|
|
|
if c, err := cpu.Info(); err != nil {
|
|
info.Errors = append(info.Errors, err)
|
|
} else {
|
|
info.CPU = c
|
|
}
|
|
|
|
return info
|
|
}
|