mirror of
https://github.com/weaveworks/scope.git
synced 2026-05-21 08:33:05 +00:00
``` $ gvt delete github.com/weaveworks/common $ gvt fetch --revision 4d96fd8dcf2c7b417912c6219b310112cb4a4626 github.com/weaveworks/common 2018/07/23 15:31:11 Fetching: github.com/weaveworks/common 2018/07/23 15:31:14 · Skipping (existing): github.com/golang/protobuf/ptypes/any 2018/07/23 15:31:14 · Fetching recursive dependency: github.com/pkg/errors 2018/07/23 15:31:16 · Skipping (existing): github.com/aws/aws-sdk-go/aws 2018/07/23 15:31:16 · Fetching recursive dependency: github.com/sirupsen/logrus 2018/07/23 15:31:18 ·· Skipping (existing): golang.org/x/sys/unix 2018/07/23 15:31:18 ·· Skipping (existing): golang.org/x/crypto/ssh/terminal 2018/07/23 15:31:18 · Skipping (existing): google.golang.org/grpc/status 2018/07/23 15:31:18 · Skipping (existing): github.com/gorilla/mux 2018/07/23 15:31:18 · Fetching recursive dependency: github.com/opentracing-contrib/go-stdlib/nethttp 2018/07/23 15:31:20 ·· Skipping (existing): github.com/opentracing/opentracing-go/ext 2018/07/23 15:31:20 ·· Skipping (existing): github.com/opentracing/opentracing-go/log 2018/07/23 15:31:20 ·· Skipping (existing): github.com/opentracing/opentracing-go 2018/07/23 15:31:20 · Skipping (existing): github.com/prometheus/client_golang/prometheus 2018/07/23 15:31:20 · Skipping (existing): google.golang.org/grpc 2018/07/23 15:31:20 · Skipping (existing): github.com/pmezard/go-difflib/difflib 2018/07/23 15:31:20 · Fetching recursive dependency: github.com/go-kit/kit/log 2018/07/23 15:31:23 ·· Fetching recursive dependency: github.com/go-logfmt/logfmt 2018/07/23 15:31:25 ··· Fetching recursive dependency: github.com/kr/logfmt 2018/07/23 15:31:27 ·· Fetching recursive dependency: github.com/go-stack/stack 2018/07/23 15:31:29 · Fetching recursive dependency: google.golang.org/genproto/googleapis/rpc/status 2018/07/23 15:31:37 ·· Skipping (existing): github.com/golang/protobuf/proto 2018/07/23 15:31:37 ·· Skipping (existing): github.com/golang/protobuf/ptypes/any 2018/07/23 15:31:37 · Skipping (existing): github.com/opentracing/opentracing-go/log 2018/07/23 15:31:37 · Fetching recursive dependency: github.com/sercand/kuberesolver 2018/07/23 15:31:39 ·· Skipping (existing): google.golang.org/grpc/grpclog 2018/07/23 15:31:39 ·· Skipping (existing): google.golang.org/grpc/resolver 2018/07/23 15:31:39 ·· Skipping (existing): golang.org/x/net/context 2018/07/23 15:31:39 · Skipping (existing): google.golang.org/grpc/metadata 2018/07/23 15:31:39 · Skipping (existing): github.com/opentracing/opentracing-go/ext 2018/07/23 15:31:39 · Skipping (existing): github.com/armon/go-socks5 2018/07/23 15:31:39 · Skipping (existing): github.com/opentracing/opentracing-go 2018/07/23 15:31:39 · Skipping (existing): github.com/davecgh/go-spew/spew 2018/07/23 15:31:39 · Skipping (existing): github.com/golang/protobuf/ptypes 2018/07/23 15:31:39 · Skipping (existing): github.com/golang/protobuf/proto 2018/07/23 15:31:39 · Fetching recursive dependency: github.com/grpc-ecosystem/grpc-opentracing/go/otgrpc 2018/07/23 15:31:41 ·· Skipping (existing): github.com/opentracing/opentracing-go/log 2018/07/23 15:31:41 ·· Skipping (existing): golang.org/x/net/context 2018/07/23 15:31:41 ·· Skipping (existing): google.golang.org/grpc/codes 2018/07/23 15:31:41 ·· Skipping (existing): github.com/golang/protobuf/proto 2018/07/23 15:31:41 ·· Skipping (existing): github.com/opentracing/opentracing-go 2018/07/23 15:31:41 ·· Skipping (existing): github.com/opentracing/opentracing-go/ext 2018/07/23 15:31:41 ·· Skipping (existing): google.golang.org/grpc 2018/07/23 15:31:41 ·· Skipping (existing): google.golang.org/grpc/metadata 2018/07/23 15:31:41 ·· Skipping (existing): google.golang.org/grpc/status 2018/07/23 15:31:41 · Fetching recursive dependency: github.com/uber/jaeger-client-go/config 2018/07/23 15:31:44 ·· Fetching recursive dependency: github.com/uber/jaeger-client-go/internal/throttler/remote 2018/07/23 15:31:44 ··· Fetching recursive dependency: github.com/uber/jaeger-client-go/utils 2018/07/23 15:31:44 ···· Fetching recursive dependency: github.com/uber/jaeger-client-go/thrift 2018/07/23 15:31:44 ···· Fetching recursive dependency: github.com/uber/jaeger-client-go/thrift-gen/agent 2018/07/23 15:31:44 ····· Fetching recursive dependency: github.com/uber/jaeger-client-go/thrift-gen/jaeger 2018/07/23 15:31:44 ····· Fetching recursive dependency: github.com/uber/jaeger-client-go/thrift-gen/zipkincore 2018/07/23 15:31:44 ··· Fetching recursive dependency: github.com/uber/jaeger-client-go 2018/07/23 15:31:44 ···· Fetching recursive dependency: github.com/crossdock/crossdock-go 2018/07/23 15:31:46 ····· Skipping (existing): github.com/davecgh/go-spew/spew 2018/07/23 15:31:46 ····· Skipping (existing): golang.org/x/net/context/ctxhttp 2018/07/23 15:31:46 ····· Skipping (existing): golang.org/x/net/context 2018/07/23 15:31:46 ····· Skipping (existing): github.com/pmezard/go-difflib/difflib 2018/07/23 15:31:46 ···· Skipping (existing): github.com/opentracing/opentracing-go/log 2018/07/23 15:31:46 ···· Fetching recursive dependency: go.uber.org/zap/zapcore 2018/07/23 15:31:49 ····· Fetching recursive dependency: go.uber.org/atomic 2018/07/23 15:31:51 ····· Fetching recursive dependency: go.uber.org/zap/internal/bufferpool 2018/07/23 15:31:51 ······ Fetching recursive dependency: go.uber.org/zap/buffer 2018/07/23 15:31:51 ····· Fetching recursive dependency: go.uber.org/multierr 2018/07/23 15:31:54 ····· Fetching recursive dependency: go.uber.org/zap/internal/exit 2018/07/23 15:31:54 ····· Fetching recursive dependency: go.uber.org/zap/internal/color 2018/07/23 15:31:54 ···· Fetching recursive dependency: go.uber.org/zap 2018/07/23 15:31:54 ···· Skipping (existing): github.com/opentracing/opentracing-go 2018/07/23 15:31:54 ···· Skipping (existing): github.com/opentracing/opentracing-go/ext 2018/07/23 15:31:54 ···· Fetching recursive dependency: github.com/uber/jaeger-lib/metrics 2018/07/23 15:31:56 ····· Fetching recursive dependency: github.com/uber-go/tally 2018/07/23 15:31:58 ······ Fetching recursive dependency: github.com/m3db/prometheus_client_golang/prometheus/promhttp 2018/07/23 15:32:00 ······· Skipping (existing): github.com/prometheus/client_golang/prometheus 2018/07/23 15:32:00 ······· Skipping (existing): github.com/prometheus/common/expfmt 2018/07/23 15:32:00 ······· Skipping (existing): github.com/prometheus/client_model/go 2018/07/23 15:32:00 ······ Fetching recursive dependency: gopkg.in/validator.v2 2018/07/23 15:32:06 ······ Fetching recursive dependency: github.com/cactus/go-statsd-client/statsd 2018/07/23 15:32:08 ······ Skipping (existing): gopkg.in/yaml.v2 2018/07/23 15:32:08 ······ Fetching recursive dependency: github.com/m3db/prometheus_client_golang/prometheus 2018/07/23 15:32:08 ······· Skipping (existing): github.com/prometheus/procfs 2018/07/23 15:32:08 ······· Skipping (existing): github.com/prometheus/client_model/go 2018/07/23 15:32:08 ······· Skipping (existing): github.com/prometheus/common/expfmt 2018/07/23 15:32:08 ······· Skipping (existing): golang.org/x/net/context 2018/07/23 15:32:08 ······· Skipping (existing): github.com/beorn7/perks/quantile 2018/07/23 15:32:08 ······· Skipping (existing): github.com/golang/protobuf/proto 2018/07/23 15:32:08 ······· Skipping (existing): github.com/prometheus/common/model 2018/07/23 15:32:08 ······· Skipping (existing): github.com/prometheus/client_golang/prometheus 2018/07/23 15:32:08 ······ Fetching recursive dependency: github.com/apache/thrift/lib/go/thrift 2018/07/23 15:32:13 ····· Skipping (existing): github.com/stretchr/testify/assert 2018/07/23 15:32:13 ····· Fetching recursive dependency: github.com/go-kit/kit/metrics/influx 2018/07/23 15:32:13 ······ Fetching recursive dependency: github.com/influxdata/influxdb/client/v2 2018/07/23 15:32:17 ······· Fetching recursive dependency: github.com/influxdata/influxdb/models 2018/07/23 15:32:17 ········ Fetching recursive dependency: github.com/influxdata/influxdb/pkg/escape 2018/07/23 15:32:17 ······ Fetching recursive dependency: github.com/go-kit/kit/metrics 2018/07/23 15:32:17 ······· Fetching recursive dependency: github.com/performancecopilot/speed 2018/07/23 15:32:19 ······· Fetching recursive dependency: github.com/aws/aws-sdk-go-v2/aws 2018/07/23 15:32:28 ········ Fetching recursive dependency: github.com/aws/aws-sdk-go-v2/internal/sdk 2018/07/23 15:32:28 ········ Skipping (existing): github.com/go-ini/ini 2018/07/23 15:32:28 ········ Fetching recursive dependency: github.com/aws/aws-sdk-go-v2/service/sts 2018/07/23 15:32:28 ········· Fetching recursive dependency: github.com/aws/aws-sdk-go-v2/private/protocol/query 2018/07/23 15:32:28 ·········· Fetching recursive dependency: github.com/aws/aws-sdk-go-v2/private/protocol 2018/07/23 15:32:28 ········· Fetching recursive dependency: github.com/aws/aws-sdk-go-v2/internal/awsutil 2018/07/23 15:32:28 ·········· Skipping (existing): github.com/jmespath/go-jmespath 2018/07/23 15:32:28 ······· Fetching recursive dependency: github.com/aws/aws-sdk-go-v2/service/cloudwatch 2018/07/23 15:32:29 ······· Skipping (existing): github.com/aws/aws-sdk-go/aws 2018/07/23 15:32:29 ······· Skipping (existing): github.com/prometheus/client_golang/prometheus 2018/07/23 15:32:29 ······· Skipping (existing): github.com/aws/aws-sdk-go/service/cloudwatch 2018/07/23 15:32:29 ······· Skipping (existing): github.com/aws/aws-sdk-go/service/cloudwatch/cloudwatchiface 2018/07/23 15:32:29 ······· Fetching recursive dependency: golang.org/x/sync/errgroup 2018/07/23 15:32:31 ········ Skipping (existing): golang.org/x/net/context 2018/07/23 15:32:31 ······· Fetching recursive dependency: github.com/go-kit/kit/util/conn 2018/07/23 15:32:31 ······· Fetching recursive dependency: github.com/VividCortex/gohistogram 2018/07/23 15:32:33 ····· Skipping (existing): github.com/prometheus/client_golang/prometheus 2018/07/23 15:32:33 ····· Fetching recursive dependency: github.com/codahale/hdrhistogram 2018/07/23 15:32:35 ·· Skipping (existing): github.com/opentracing/opentracing-go 2018/07/23 15:32:35 · Fetching recursive dependency: github.com/mwitkow/go-grpc-middleware 2018/07/23 15:32:37 ·· Fetching recursive dependency: github.com/grpc-ecosystem/go-grpc-middleware/logging 2018/07/23 15:32:39 ··· Fetching recursive dependency: github.com/grpc-ecosystem/go-grpc-middleware 2018/07/23 15:32:39 ···· Fetching recursive dependency: github.com/golang/protobuf/jsonpb 2018/07/23 15:32:42 ····· Skipping (existing): github.com/golang/protobuf/ptypes/timestamp 2018/07/23 15:32:42 ····· Skipping (existing): github.com/golang/protobuf/proto 2018/07/23 15:32:42 ····· Skipping (existing): github.com/golang/protobuf/ptypes/duration 2018/07/23 15:32:42 ····· Skipping (existing): github.com/golang/protobuf/ptypes/any 2018/07/23 15:32:42 ····· Skipping (existing): github.com/golang/protobuf/ptypes/struct 2018/07/23 15:32:42 ····· Skipping (existing): github.com/golang/protobuf/ptypes/wrappers 2018/07/23 15:32:42 ···· Skipping (existing): google.golang.org/grpc/metadata 2018/07/23 15:32:42 ···· Fetching recursive dependency: github.com/stretchr/testify/suite 2018/07/23 15:32:45 ····· Skipping (existing): github.com/stretchr/testify/assert 2018/07/23 15:32:45 ····· Fetching recursive dependency: github.com/stretchr/testify/require 2018/07/23 15:32:45 ······ Skipping (existing): github.com/stretchr/testify/assert 2018/07/23 15:32:45 ···· Skipping (existing): google.golang.org/grpc/peer 2018/07/23 15:32:45 ···· Skipping (existing): golang.org/x/net/context 2018/07/23 15:32:45 ···· Skipping (existing): golang.org/x/net/trace 2018/07/23 15:32:45 ···· Fetching recursive dependency: github.com/gogo/protobuf/gogoproto 2018/07/23 15:32:48 ····· Fetching recursive dependency: github.com/gogo/protobuf/protoc-gen-gogo/descriptor 2018/07/23 15:32:48 ······ Skipping (existing): github.com/gogo/protobuf/proto 2018/07/23 15:32:48 ····· Skipping (existing): github.com/gogo/protobuf/proto 2018/07/23 15:32:48 ···· Skipping (existing): google.golang.org/grpc/credentials 2018/07/23 15:32:48 ···· Skipping (existing): google.golang.org/grpc 2018/07/23 15:32:48 ···· Skipping (existing): github.com/opentracing/opentracing-go 2018/07/23 15:32:48 ···· Skipping (existing): google.golang.org/grpc/codes 2018/07/23 15:32:48 ···· Skipping (existing): github.com/golang/protobuf/proto 2018/07/23 15:32:48 ···· Skipping (existing): google.golang.org/grpc/grpclog 2018/07/23 15:32:48 ···· Skipping (existing): github.com/opentracing/opentracing-go/ext 2018/07/23 15:32:48 ···· Skipping (existing): github.com/opentracing/opentracing-go/log 2018/07/23 15:32:48 ··· Skipping (existing): golang.org/x/net/context 2018/07/23 15:32:48 ··· Skipping (existing): google.golang.org/grpc 2018/07/23 15:32:48 ··· Skipping (existing): google.golang.org/grpc/grpclog 2018/07/23 15:32:48 ··· Skipping (existing): google.golang.org/grpc/codes 2018/07/23 15:32:48 ··· Skipping (existing): github.com/golang/protobuf/proto 2018/07/23 15:32:48 ·· Skipping (existing): github.com/opentracing/opentracing-go 2018/07/23 15:32:48 ·· Skipping (existing): google.golang.org/grpc 2018/07/23 15:32:48 ·· Skipping (existing): golang.org/x/net/context 2018/07/23 15:32:48 ·· Skipping (existing): google.golang.org/grpc/codes 2018/07/23 15:32:48 ·· Skipping (existing): google.golang.org/grpc/grpclog 2018/07/23 15:32:48 ·· Skipping (existing): github.com/opentracing/opentracing-go/log 2018/07/23 15:32:48 ·· Skipping (existing): google.golang.org/grpc/metadata 2018/07/23 15:32:48 ·· Skipping (existing): google.golang.org/grpc/peer 2018/07/23 15:32:48 ·· Skipping (existing): google.golang.org/grpc/credentials 2018/07/23 15:32:48 ·· Skipping (existing): github.com/golang/protobuf/proto 2018/07/23 15:32:48 ·· Skipping (existing): golang.org/x/net/trace 2018/07/23 15:32:48 ·· Skipping (existing): github.com/opentracing/opentracing-go/ext 2018/07/23 15:32:48 · Fetching recursive dependency: github.com/weaveworks/promrus 2018/07/23 15:32:53 ·· Skipping (existing): gopkg.in/yaml.v2 2018/07/23 15:32:53 ·· Skipping (existing): golang.org/x/net/context/ctxhttp 2018/07/23 15:32:53 ·· Fetching recursive dependency: github.com/stretchr/objx 2018/07/23 15:32:55 ·· Fetching recursive dependency: gopkg.in/alecthomas/kingpin.v2 2018/07/23 15:32:58 ··· Fetching recursive dependency: github.com/alecthomas/units 2018/07/23 15:33:00 ··· Fetching recursive dependency: github.com/alecthomas/template 2018/07/23 15:33:02 ·· Fetching recursive dependency: github.com/julienschmidt/httprouter 2018/07/23 15:33:05 ·· Skipping (existing): golang.org/x/net/context 2018/07/23 15:33:05 · Skipping (existing): github.com/aws/aws-sdk-go/aws/credentials 2018/07/23 15:33:05 · Skipping (existing): github.com/golang/protobuf/ptypes/empty 2018/07/23 15:33:05 · Skipping (existing): golang.org/x/net/context 2018/07/23 15:33:05 · Skipping (existing): golang.org/x/tools/cover 2018/07/23 15:33:05 · Skipping (existing): github.com/mgutz/ansi ```
328 lines
8.2 KiB
Go
328 lines
8.2 KiB
Go
// Copyright (c) 2012-2016 Eli Janssen
|
|
// Use of this source code is governed by an MIT-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package statsd
|
|
|
|
import (
|
|
"fmt"
|
|
"math/rand"
|
|
"strconv"
|
|
"strings"
|
|
"time"
|
|
)
|
|
|
|
var bufPool = newBufferPool()
|
|
|
|
// The StatSender interface wraps all the statsd metric methods
|
|
type StatSender interface {
|
|
Inc(string, int64, float32) error
|
|
Dec(string, int64, float32) error
|
|
Gauge(string, int64, float32) error
|
|
GaugeDelta(string, int64, float32) error
|
|
Timing(string, int64, float32) error
|
|
TimingDuration(string, time.Duration, float32) error
|
|
Set(string, string, float32) error
|
|
SetInt(string, int64, float32) error
|
|
Raw(string, string, float32) error
|
|
}
|
|
|
|
// The Statter interface defines the behavior of a stat client
|
|
type Statter interface {
|
|
StatSender
|
|
NewSubStatter(string) SubStatter
|
|
SetPrefix(string)
|
|
Close() error
|
|
}
|
|
|
|
// The SubStatter interface defines the behavior of a stat child/subclient
|
|
type SubStatter interface {
|
|
StatSender
|
|
SetSamplerFunc(SamplerFunc)
|
|
NewSubStatter(string) SubStatter
|
|
}
|
|
|
|
// The SamplerFunc type defines a function that can serve
|
|
// as a Client sampler function.
|
|
type SamplerFunc func(float32) bool
|
|
|
|
// DefaultSampler is the default rate sampler function
|
|
func DefaultSampler(rate float32) bool {
|
|
if rate < 1 {
|
|
return rand.Float32() < rate
|
|
}
|
|
return true
|
|
}
|
|
|
|
// A Client is a statsd client.
|
|
type Client struct {
|
|
// prefix for statsd name
|
|
prefix string
|
|
// packet sender
|
|
sender Sender
|
|
// sampler method
|
|
sampler SamplerFunc
|
|
}
|
|
|
|
// Close closes the connection and cleans up.
|
|
func (s *Client) Close() error {
|
|
if s == nil {
|
|
return nil
|
|
}
|
|
|
|
err := s.sender.Close()
|
|
return err
|
|
}
|
|
|
|
// Inc increments a statsd count type.
|
|
// stat is a string name for the metric.
|
|
// value is the integer value
|
|
// rate is the sample rate (0.0 to 1.0)
|
|
func (s *Client) Inc(stat string, value int64, rate float32) error {
|
|
if !s.includeStat(rate) {
|
|
return nil
|
|
}
|
|
|
|
return s.submit(stat, "", value, "|c", rate)
|
|
}
|
|
|
|
// Dec decrements a statsd count type.
|
|
// stat is a string name for the metric.
|
|
// value is the integer value.
|
|
// rate is the sample rate (0.0 to 1.0).
|
|
func (s *Client) Dec(stat string, value int64, rate float32) error {
|
|
if !s.includeStat(rate) {
|
|
return nil
|
|
}
|
|
|
|
return s.submit(stat, "", -value, "|c", rate)
|
|
}
|
|
|
|
// Gauge submits/updates a statsd gauge type.
|
|
// stat is a string name for the metric.
|
|
// value is the integer value.
|
|
// rate is the sample rate (0.0 to 1.0).
|
|
func (s *Client) Gauge(stat string, value int64, rate float32) error {
|
|
if !s.includeStat(rate) {
|
|
return nil
|
|
}
|
|
|
|
return s.submit(stat, "", value, "|g", rate)
|
|
}
|
|
|
|
// GaugeDelta submits a delta to a statsd gauge.
|
|
// stat is the string name for the metric.
|
|
// value is the (positive or negative) change.
|
|
// rate is the sample rate (0.0 to 1.0).
|
|
func (s *Client) GaugeDelta(stat string, value int64, rate float32) error {
|
|
if !s.includeStat(rate) {
|
|
return nil
|
|
}
|
|
|
|
// if negative, the submit formatter will prefix with a - already
|
|
// so only special case the positive value
|
|
if value >= 0 {
|
|
return s.submit(stat, "+", value, "|g", rate)
|
|
}
|
|
return s.submit(stat, "", value, "|g", rate)
|
|
}
|
|
|
|
// Timing submits a statsd timing type.
|
|
// stat is a string name for the metric.
|
|
// delta is the time duration value in milliseconds
|
|
// rate is the sample rate (0.0 to 1.0).
|
|
func (s *Client) Timing(stat string, delta int64, rate float32) error {
|
|
if !s.includeStat(rate) {
|
|
return nil
|
|
}
|
|
|
|
return s.submit(stat, "", delta, "|ms", rate)
|
|
}
|
|
|
|
// TimingDuration submits a statsd timing type.
|
|
// stat is a string name for the metric.
|
|
// delta is the timing value as time.Duration
|
|
// rate is the sample rate (0.0 to 1.0).
|
|
func (s *Client) TimingDuration(stat string, delta time.Duration, rate float32) error {
|
|
if !s.includeStat(rate) {
|
|
return nil
|
|
}
|
|
|
|
ms := float64(delta) / float64(time.Millisecond)
|
|
return s.submit(stat, "", ms, "|ms", rate)
|
|
}
|
|
|
|
// Set submits a stats set type
|
|
// stat is a string name for the metric.
|
|
// value is the string value
|
|
// rate is the sample rate (0.0 to 1.0).
|
|
func (s *Client) Set(stat string, value string, rate float32) error {
|
|
if !s.includeStat(rate) {
|
|
return nil
|
|
}
|
|
|
|
return s.submit(stat, "", value, "|s", rate)
|
|
}
|
|
|
|
// SetInt submits a number as a stats set type.
|
|
// stat is a string name for the metric.
|
|
// value is the integer value
|
|
// rate is the sample rate (0.0 to 1.0).
|
|
func (s *Client) SetInt(stat string, value int64, rate float32) error {
|
|
if !s.includeStat(rate) {
|
|
return nil
|
|
}
|
|
|
|
return s.submit(stat, "", value, "|s", rate)
|
|
}
|
|
|
|
// Raw submits a preformatted value.
|
|
// stat is the string name for the metric.
|
|
// value is a preformatted "raw" value string.
|
|
// rate is the sample rate (0.0 to 1.0).
|
|
func (s *Client) Raw(stat string, value string, rate float32) error {
|
|
if !s.includeStat(rate) {
|
|
return nil
|
|
}
|
|
|
|
return s.submit(stat, "", value, "", rate)
|
|
}
|
|
|
|
// SetSamplerFunc sets a sampler function to something other than the default
|
|
// sampler is a function that determines whether the metric is
|
|
// to be accepted, or discarded.
|
|
// An example use case is for submitted pre-sampled metrics.
|
|
func (s *Client) SetSamplerFunc(sampler SamplerFunc) {
|
|
s.sampler = sampler
|
|
}
|
|
|
|
// submit an already sampled raw stat
|
|
func (s *Client) submit(stat, vprefix string, value interface{}, suffix string, rate float32) error {
|
|
data := bufPool.Get()
|
|
defer bufPool.Put(data)
|
|
|
|
if s.prefix != "" {
|
|
data.WriteString(s.prefix)
|
|
data.WriteString(".")
|
|
}
|
|
|
|
data.WriteString(stat)
|
|
data.WriteString(":")
|
|
|
|
if vprefix != "" {
|
|
data.WriteString(vprefix)
|
|
}
|
|
|
|
// sadly, no way to jam this back into the bytes.Buffer without
|
|
// doing a few allocations... avoiding those is the whole point here...
|
|
// so from here on out just use it as a raw []byte
|
|
b := data.Bytes()
|
|
|
|
switch v := value.(type) {
|
|
case string:
|
|
b = append(b, v...)
|
|
case int64:
|
|
b = strconv.AppendInt(b, v, 10)
|
|
case float64:
|
|
b = strconv.AppendFloat(b, v, 'f', -1, 64)
|
|
default:
|
|
return fmt.Errorf("No matching type format")
|
|
}
|
|
|
|
if suffix != "" {
|
|
b = append(b, suffix...)
|
|
}
|
|
|
|
if rate < 1 {
|
|
b = append(b, "|@"...)
|
|
b = strconv.AppendFloat(b, float64(rate), 'f', 6, 32)
|
|
}
|
|
|
|
_, err := s.sender.Send(b)
|
|
return err
|
|
}
|
|
|
|
// check for nil client, and perform sampling calculation
|
|
func (s *Client) includeStat(rate float32) bool {
|
|
if s == nil {
|
|
return false
|
|
}
|
|
|
|
// test for nil in case someone builds their own
|
|
// client without calling new (result is nil sampler)
|
|
if s.sampler != nil {
|
|
return s.sampler(rate)
|
|
}
|
|
return DefaultSampler(rate)
|
|
}
|
|
|
|
// SetPrefix sets/updates the statsd client prefix.
|
|
// Note: Does not change the prefix of any SubStatters.
|
|
func (s *Client) SetPrefix(prefix string) {
|
|
if s == nil {
|
|
return
|
|
}
|
|
|
|
s.prefix = prefix
|
|
}
|
|
|
|
// NewSubStatter returns a SubStatter with appended prefix
|
|
func (s *Client) NewSubStatter(prefix string) SubStatter {
|
|
var c *Client
|
|
if s != nil {
|
|
c = &Client{
|
|
prefix: joinPathComp(s.prefix, prefix),
|
|
sender: s.sender,
|
|
sampler: s.sampler,
|
|
}
|
|
}
|
|
return c
|
|
}
|
|
|
|
// NewClient returns a pointer to a new Client, and an error.
|
|
//
|
|
// addr is a string of the format "hostname:port", and must be parsable by
|
|
// net.ResolveUDPAddr.
|
|
//
|
|
// prefix is the statsd client prefix. Can be "" if no prefix is desired.
|
|
func NewClient(addr, prefix string) (Statter, error) {
|
|
sender, err := NewSimpleSender(addr)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &Client{prefix: prefix, sender: sender}, nil
|
|
}
|
|
|
|
// NewClientWithSender returns a pointer to a new Client and an error.
|
|
//
|
|
// sender is an instance of a statsd.Sender interface and may not be nil
|
|
//
|
|
// prefix is the stastd client prefix. Can be "" if no prefix is desired.
|
|
func NewClientWithSender(sender Sender, prefix string) (Statter, error) {
|
|
if sender == nil {
|
|
return nil, fmt.Errorf("Client sender may not be nil")
|
|
}
|
|
|
|
return &Client{prefix: prefix, sender: sender}, nil
|
|
}
|
|
|
|
// joinPathComp is a helper that ensures we combine path components with a dot
|
|
// when it's appropriate to do so; prefix is the existing prefix and suffix is
|
|
// the new component being added.
|
|
//
|
|
// It returns the joined prefix.
|
|
func joinPathComp(prefix, suffix string) string {
|
|
suffix = strings.TrimLeft(suffix, ".")
|
|
if prefix != "" && suffix != "" {
|
|
return prefix + "." + suffix
|
|
}
|
|
return prefix + suffix
|
|
}
|
|
|
|
// Dial is a compatibility alias for NewClient
|
|
var Dial = NewClient
|
|
|
|
// New is a compatibility alias for NewClient
|
|
var New = NewClient
|