73 lines
2.5 KiB
Go
73 lines
2.5 KiB
Go
|
// Copyright (c) 2012, Matt T. Proud
|
||
|
// All rights reserved.
|
||
|
//
|
||
|
// Use of this source code is governed by a BSD-style
|
||
|
// license that can be found in the LICENSE file.
|
||
|
|
||
|
// main.go provides a simple example of how to use this instrumentation
|
||
|
// framework in the context of having something that emits values into
|
||
|
// its collectors.
|
||
|
//
|
||
|
// The emitted values correspond to uniform, normal, and exponential
|
||
|
// distributions.
|
||
|
|
||
|
package main
|
||
|
|
||
|
import (
|
||
|
"github.com/matttproud/golang_instrumentation"
|
||
|
"github.com/matttproud/golang_instrumentation/maths"
|
||
|
"github.com/matttproud/golang_instrumentation/metrics"
|
||
|
"math/rand"
|
||
|
"net/http"
|
||
|
"time"
|
||
|
)
|
||
|
|
||
|
func main() {
|
||
|
foo_rpc_latency := metrics.CreateHistogram(&metrics.HistogramSpecification{
|
||
|
Starts: metrics.EquallySizedBucketsFor(0, 200, 4),
|
||
|
BucketMaker: metrics.AccumulatingBucketBuilder(metrics.EvictAndReplaceWith(10, maths.Average), 50),
|
||
|
ReportablePercentiles: []float64{0.01, 0.05, 0.5, 0.90, 0.99},
|
||
|
})
|
||
|
foo_rpc_calls := &metrics.GaugeMetric{}
|
||
|
bar_rpc_latency := metrics.CreateHistogram(&metrics.HistogramSpecification{
|
||
|
Starts: metrics.EquallySizedBucketsFor(0, 200, 4),
|
||
|
BucketMaker: metrics.AccumulatingBucketBuilder(metrics.EvictAndReplaceWith(10, maths.Average), 50),
|
||
|
ReportablePercentiles: []float64{0.01, 0.05, 0.5, 0.90, 0.99},
|
||
|
})
|
||
|
bar_rpc_calls := &metrics.GaugeMetric{}
|
||
|
zed_rpc_latency := metrics.CreateHistogram(&metrics.HistogramSpecification{
|
||
|
Starts: metrics.EquallySizedBucketsFor(0, 200, 4),
|
||
|
BucketMaker: metrics.AccumulatingBucketBuilder(metrics.EvictAndReplaceWith(10, maths.Average), 50),
|
||
|
ReportablePercentiles: []float64{0.01, 0.05, 0.5, 0.90, 0.99},
|
||
|
})
|
||
|
zed_rpc_calls := &metrics.GaugeMetric{}
|
||
|
|
||
|
metrics := registry.NewRegistry()
|
||
|
metrics.Register("foo_rpc_latency_ms_histogram", foo_rpc_latency)
|
||
|
metrics.Register("foo_rpc_call_count", foo_rpc_calls)
|
||
|
metrics.Register("bar_rpc_latency_ms_histogram", bar_rpc_latency)
|
||
|
metrics.Register("bar_rpc_call_count", bar_rpc_calls)
|
||
|
metrics.Register("zed_rpc_latency_ms_histogram", zed_rpc_latency)
|
||
|
metrics.Register("zed_rpc_call_count", zed_rpc_calls)
|
||
|
|
||
|
go func() {
|
||
|
for {
|
||
|
foo_rpc_latency.Add(rand.Float64() * 200)
|
||
|
foo_rpc_calls.Increment()
|
||
|
|
||
|
bar_rpc_latency.Add((rand.NormFloat64() * 10.0) + 100.0)
|
||
|
bar_rpc_calls.Increment()
|
||
|
|
||
|
zed_rpc_latency.Add(rand.ExpFloat64())
|
||
|
zed_rpc_calls.Increment()
|
||
|
|
||
|
time.Sleep(100 * time.Millisecond)
|
||
|
}
|
||
|
}()
|
||
|
|
||
|
exporter := metrics.YieldExporter()
|
||
|
|
||
|
http.Handle("/metrics.json", exporter)
|
||
|
http.ListenAndServe(":8080", nil)
|
||
|
}
|