暫無描述

mihasya 4df3bc4601 deprecate the graphite client in favor of the new separate lib 10 年之前
cmd 68b130797a initial implementation of GaugeFloat64 11 年之前
influxdb 0f75ec011f Update influxdb.go 11 年之前
librato 15886a6fca deprecate librato client + add reference to new home 10 年之前
stathat 68b130797a initial implementation of GaugeFloat64 11 年之前
.gitignore 7b8f3191d7 never-read debugging tool. 12 年之前
LICENSE cf3de86166 Updated docs, deleted Makefiles. 13 年之前
README.md 4df3bc4601 deprecate the graphite client in favor of the new separate lib 10 年之前
counter.go b29332614c Allow lazy instantiation of metric in GetOrRegister. 11 年之前
counter_test.go 10aaf9c455 Fully introduce snapshots for all metric types. 12 年之前
debug.go 3331190d5f Use time.Tick everywhere else we should, too 11 年之前
debug_test.go a4a3178f75 Skip tests that require GOMAXPROCS > 1. 12 年之前
ewma.go f9ee67ed7c ewma: ensure 64-bit alignment of uncounted 12 年之前
ewma_test.go ddac18df1e Benchmarks for everyone! 12 年之前
gauge.go b29332614c Allow lazy instantiation of metric in GetOrRegister. 11 年之前
gauge_float64.go 37df06ff62 Do not export methods from sync.Mutex on gauges. 11 年之前
gauge_float64_test.go 52781178b7 Tidying whitespace. 11 年之前
gauge_test.go 10aaf9c455 Fully introduce snapshots for all metric types. 12 年之前
graphite.go 4df3bc4601 deprecate the graphite client in favor of the new separate lib 10 年之前
graphite_test.go 40dc4126bb Allow custom percentiles to report to Graphite 11 年之前
healthcheck.go 6bd8d76861 Mostly documentation and naming changes. 12 年之前
histogram.go d4f1d62226 Alphabetize 11 年之前
histogram_test.go 6fa35ede17 Fix tests broken by sample changes. 12 年之前
json.go 7f86fc7d84 Fix registry race caused by copying a sync.Mutex 11 年之前
json_test.go 6d82eb1add Added JSON->io.Writer; consistent ordering to WriteOnce 11 年之前
log.go 3331190d5f Use time.Tick everywhere else we should, too 11 年之前
memory.md 033e0dc4eb Installation and usage. 14 年之前
meter.go f770e6f5e9 Fix Meter.RateMean int64 overflow 11 年之前
meter_test.go 0c229a5e1b Use a single goroutine for meters. 11 年之前
metrics.go b953f7c0d8 ETOOCLEVER so s/ObserverEffect/UseNilMetrics/. 12 年之前
metrics_test.go 68b130797a initial implementation of GaugeFloat64 11 年之前
opentsdb.go ddd7a221c0 Fix #74 for OpenTSDB, too 11 年之前
opentsdb_test.go 490281a63d add opentsdb support 11 年之前
registry.go 1a72544ea8 Fix #100 by reading len within the lock 10 年之前
registry_test.go 426a4331b7 Return an error from Register and disallow dupes 11 年之前
runtime.go db420d79fc Fix reporting for NumCgoCall() and apply go fmt 11 年之前
runtime_cgo.go 43da0d067c Fixes: Won't compile on AppEngine #67 11 年之前
runtime_no_cgo.go 43da0d067c Fixes: Won't compile on AppEngine #67 11 年之前
runtime_test.go 10272f002f Rework NumGC and PauseNs runtime metrics. 11 年之前
sample.go a5cfc242a5 Prevent most allocations in ExpDecaySample 10 年之前
sample_test.go 670402e738 Test for #104 10 年之前
syslog.go 3331190d5f Use time.Tick everywhere else we should, too 11 年之前
timer.go d4f1d62226 Alphabetize 11 年之前
timer_test.go 6fa35ede17 Fix tests broken by sample changes. 12 年之前
writer.go 3331190d5f Use time.Tick everywhere else we should, too 11 年之前
writer_test.go 6370c0ca61 Merge branch 'master' of github.com:stuartcarnie/go-metrics 11 年之前

README.md

go-metrics

Go port of Coda Hale's Metrics library: https://github.com/dropwizard/metrics.

Documentation: http://godoc.org/github.com/rcrowley/go-metrics.

Usage

Create and update metrics:

c := metrics.NewCounter()
metrics.Register("foo", c)
c.Inc(47)

g := metrics.NewGauge()
metrics.Register("bar", g)
g.Update(47)

s := metrics.NewExpDecaySample(1028, 0.015) // or metrics.NewUniformSample(1028)
h := metrics.NewHistogram(s)
metrics.Register("baz", h)
h.Update(47)

m := metrics.NewMeter()
metrics.Register("quux", m)
m.Mark(47)

t := metrics.NewTimer()
metrics.Register("bang", t)
t.Time(func() {})
t.Update(47)

Periodically log every metric in human-readable form to standard error:

go metrics.Log(metrics.DefaultRegistry, 60e9, log.New(os.Stderr, "metrics: ", log.Lmicroseconds))

Periodically log every metric in slightly-more-parseable form to syslog:

w, _ := syslog.Dial("unixgram", "/dev/log", syslog.LOG_INFO, "metrics")
go metrics.Syslog(metrics.DefaultRegistry, 60e9, w)

Periodically emit every metric to Graphite using the Graphite client:


import "github.com/cyberdelia/go-metrics-graphite"

addr, _ := net.ResolveTCPAddr("tcp", "127.0.0.1:2003")
go graphite.Graphite(metrics.DefaultRegistry, 10e9, "metrics", addr)

Periodically emit every metric into InfluxDB:

import "github.com/rcrowley/go-metrics/influxdb"

go influxdb.Influxdb(metrics.DefaultRegistry, 10e9, &influxdb.Config{
    Host:     "127.0.0.1:8086",
    Database: "metrics",
    Username: "test",
    Password: "test",
})

Periodically upload every metric to Librato using the Librato client:

Note: the client included with this repository under the librato package has been deprecated and moved to the repository linked above.

import "github.com/mihasya/go-metrics-librato"

go librato.Librato(metrics.DefaultRegistry,
    10e9,                  // interval
    "example@example.com", // account owner email address
    "token",               // Librato API token
    "hostname",            // source
    []float64{0.95},       // percentiles to send
    time.Millisecond,      // time unit
)

Periodically emit every metric to StatHat:

import "github.com/rcrowley/go-metrics/stathat"

go stathat.Stathat(metrics.DefaultRegistry, 10e9, "example@example.com")

Installation

go get github.com/rcrowley/go-metrics

StatHat support additionally requires their Go client:

go get github.com/stathat/go

Publishing Metrics

Clients are available for the following destinations: