forked from LaconicNetwork/kompose
|
|
||
|---|---|---|
| .. | ||
| .gitignore | ||
| collector.go | ||
| counter.go | ||
| desc.go | ||
| doc.go | ||
| expvar.go | ||
| gauge.go | ||
| go_collector.go | ||
| histogram.go | ||
| http.go | ||
| metric.go | ||
| process_collector.go | ||
| push.go | ||
| README.md | ||
| registry.go | ||
| summary.go | ||
| untyped.go | ||
| value.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)
}
