.. | ||
.gitignore | ||
benchmark_test.go | ||
collector.go | ||
counter_test.go | ||
counter.go | ||
desc.go | ||
doc.go | ||
example_clustermanager_test.go | ||
example_memstats_test.go | ||
example_selfcollector_test.go | ||
examples_test.go | ||
expvar_test.go | ||
expvar.go | ||
fnv.go | ||
gauge_test.go | ||
gauge.go | ||
go_collector_test.go | ||
go_collector.go | ||
histogram_test.go | ||
histogram.go | ||
http_test.go | ||
http.go | ||
metric_test.go | ||
metric.go | ||
process_collector_test.go | ||
process_collector.go | ||
push.go | ||
README.md | ||
registry_test.go | ||
registry.go | ||
summary_test.go | ||
summary.go | ||
untyped.go | ||
value.go | ||
vec_test.go | ||
vec.go |
Overview
This is the Prometheus telemetric instrumentation client Go client library. It enable authors to define process-space metrics for their servers and expose them through a web service interface for extraction, aggregation, and a whole slew of other post processing techniques.
Installing
$ go get github.com/prometheus/client_golang/prometheus
Example
package main
import (
"net/http"
"github.com/prometheus/client_golang/prometheus"
)
var (
indexed = prometheus.NewCounter(prometheus.CounterOpts{
Namespace: "my_company",
Subsystem: "indexer",
Name: "documents_indexed",
Help: "The number of documents indexed.",
})
size = prometheus.NewGauge(prometheus.GaugeOpts{
Namespace: "my_company",
Subsystem: "storage",
Name: "documents_total_size_bytes",
Help: "The total size of all documents in the storage.",
})
)
func main() {
http.Handle("/metrics", prometheus.Handler())
indexed.Inc()
size.Set(5)
http.ListenAndServe(":8080", nil)
}
func init() {
prometheus.MustRegister(indexed)
prometheus.MustRegister(size)
}