forked from DataDog/dd-trace-go
-
Notifications
You must be signed in to change notification settings - Fork 0
/
metrics.go
103 lines (94 loc) · 4.35 KB
/
metrics.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
// Unless explicitly stated otherwise all files in this repository are licensed
// under the Apache License Version 2.0.
// This product includes software developed at Datadog (https://www.datadoghq.com/).
// Copyright 2016-2019 Datadog, Inc.
package tracer
import (
"runtime"
"runtime/debug"
"time"
"gopkg.in/DataDog/dd-trace-go.v1/ddtrace/ext"
"gopkg.in/DataDog/dd-trace-go.v1/internal/log"
)
// defaultMetricsReportInterval specifies the interval at which runtime metrics will
// be reported.
const defaultMetricsReportInterval = 10 * time.Second
type gauger interface {
Gauge(name string, value float64, tags []string, rate float64) error
}
// reportMetrics periodically reports go runtime metrics to the specified gauger at
// the given interval.
func (t *tracer) reportMetrics(statsd gauger, interval time.Duration) {
var (
ms runtime.MemStats
tags []string
)
if t.config.serviceName != "" {
tags = append(tags, "service:"+t.config.serviceName)
}
if t.config.hostname != "" {
tags = append(tags, "host:"+t.config.hostname)
}
if v, ok := t.config.globalTags[ext.Environment]; ok {
if vv, ok := v.(string); ok {
tags = append(tags, "env:"+vv)
}
}
gc := debug.GCStats{
// When len(stats.PauseQuantiles) is 5, it will be filled with the
// minimum, 25%, 50%, 75%, and maximum pause times. See the documentation
// for (runtime/debug).ReadGCStats.
PauseQuantiles: make([]time.Duration, 5),
}
tick := time.NewTicker(interval)
defer tick.Stop()
for {
select {
case <-tick.C:
log.Debug("Reporting runtime metrics...")
runtime.ReadMemStats(&ms)
debug.ReadGCStats(&gc)
// CPU statistics
statsd.Gauge("runtime.go.num_cpu", float64(runtime.NumCPU()), tags, 1)
statsd.Gauge("runtime.go.num_goroutine", float64(runtime.NumGoroutine()), tags, 1)
statsd.Gauge("runtime.go.num_cgo_call", float64(runtime.NumCgoCall()), tags, 1)
// General statistics
statsd.Gauge("runtime.go.mem_stats.alloc", float64(ms.Alloc), tags, 1)
statsd.Gauge("runtime.go.mem_stats.total_alloc", float64(ms.TotalAlloc), tags, 1)
statsd.Gauge("runtime.go.mem_stats.sys", float64(ms.Sys), tags, 1)
statsd.Gauge("runtime.go.mem_stats.lookups", float64(ms.Lookups), tags, 1)
statsd.Gauge("runtime.go.mem_stats.mallocs", float64(ms.Mallocs), tags, 1)
statsd.Gauge("runtime.go.mem_stats.frees", float64(ms.Frees), tags, 1)
// Heap memory statistics
statsd.Gauge("runtime.go.mem_stats.heap_alloc", float64(ms.HeapAlloc), tags, 1)
statsd.Gauge("runtime.go.mem_stats.heap_sys", float64(ms.HeapSys), tags, 1)
statsd.Gauge("runtime.go.mem_stats.heap_idle", float64(ms.HeapIdle), tags, 1)
statsd.Gauge("runtime.go.mem_stats.heap_inuse", float64(ms.HeapInuse), tags, 1)
statsd.Gauge("runtime.go.mem_stats.heap_released", float64(ms.HeapReleased), tags, 1)
statsd.Gauge("runtime.go.mem_stats.heap_objects", float64(ms.HeapObjects), tags, 1)
// Stack memory statistics
statsd.Gauge("runtime.go.mem_stats.stack_inuse", float64(ms.StackInuse), tags, 1)
statsd.Gauge("runtime.go.mem_stats.stack_sys", float64(ms.StackSys), tags, 1)
// Off-heap memory statistics
statsd.Gauge("runtime.go.mem_stats.m_span_inuse", float64(ms.MSpanInuse), tags, 1)
statsd.Gauge("runtime.go.mem_stats.m_span_sys", float64(ms.MSpanSys), tags, 1)
statsd.Gauge("runtime.go.mem_stats.m_cache_inuse", float64(ms.MCacheInuse), tags, 1)
statsd.Gauge("runtime.go.mem_stats.m_cache_sys", float64(ms.MCacheSys), tags, 1)
statsd.Gauge("runtime.go.mem_stats.buck_hash_sys", float64(ms.BuckHashSys), tags, 1)
statsd.Gauge("runtime.go.mem_stats.gc_sys", float64(ms.GCSys), tags, 1)
statsd.Gauge("runtime.go.mem_stats.other_sys", float64(ms.OtherSys), tags, 1)
// Garbage collector statistics
statsd.Gauge("runtime.go.mem_stats.next_gc", float64(ms.NextGC), tags, 1)
statsd.Gauge("runtime.go.mem_stats.last_gc", float64(ms.LastGC), tags, 1)
statsd.Gauge("runtime.go.mem_stats.pause_total_ns", float64(ms.PauseTotalNs), tags, 1)
statsd.Gauge("runtime.go.mem_stats.num_gc", float64(ms.NumGC), tags, 1)
statsd.Gauge("runtime.go.mem_stats.num_forced_gc", float64(ms.NumForcedGC), tags, 1)
statsd.Gauge("runtime.go.mem_stats.gc_cpu_fraction", ms.GCCPUFraction, tags, 1)
for i, p := range []string{"min", "25p", "50p", "75p", "max"} {
statsd.Gauge("runtime.go.gc_stats.pause_quantiles."+p, float64(gc.PauseQuantiles[i]), tags, 1)
}
case <-t.stopped:
return
}
}
}