Files
weave-scope/common/instrument/instrument.go
2016-07-05 12:29:00 +01:00

42 lines
1.2 KiB
Go

package instrument
import (
"time"
"github.com/prometheus/client_golang/prometheus"
)
// ErrorCode converts an error in to an http-style error-code.
func ErrorCode(err error) string {
if err == nil {
return "200"
}
return "500"
}
// TimeRequest runs 'f' and records how long it took in the given Prometheus
// metric. If 'f' returns successfully, record a "200". Otherwise, record
// "500".
//
// If you want more complicated logic for translating errors into statuses,
// use 'TimeRequestStatus'.
func TimeRequest(method string, metric *prometheus.SummaryVec, f func() error) error {
return TimeRequestStatus(method, metric, ErrorCode, f)
}
// TimeRequestStatus runs 'f' and records how long it took in the given
// Prometheus metric.
//
// toStatusCode is a function that translates errors returned by 'f' into
// HTTP-like status codes.
func TimeRequestStatus(method string, metric *prometheus.SummaryVec, toStatusCode func(error) string, f func() error) error {
if toStatusCode == nil {
toStatusCode = ErrorCode
}
startTime := time.Now()
err := f()
duration := time.Now().Sub(startTime)
metric.WithLabelValues(method, toStatusCode(err)).Observe(duration.Seconds())
return err
}