summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--cmd/rr/http/metrics.go2
-rw-r--r--service/metrics/rpc.go60
2 files changed, 60 insertions, 2 deletions
diff --git a/cmd/rr/http/metrics.go b/cmd/rr/http/metrics.go
index 32e4a6cd..21bbbaf1 100644
--- a/cmd/rr/http/metrics.go
+++ b/cmd/rr/http/metrics.go
@@ -55,7 +55,7 @@ func newCollector() *metricCollector {
),
requestDuration: prometheus.NewHistogramVec(
prometheus.HistogramOpts{
- Name: "rr_http_request_seconds",
+ Name: "rr_http_request_duration_seconds",
Help: "HTTP request duration.",
},
[]string{"status"},
diff --git a/service/metrics/rpc.go b/service/metrics/rpc.go
index b0023d73..30ad6c62 100644
--- a/service/metrics/rpc.go
+++ b/service/metrics/rpc.go
@@ -7,6 +7,7 @@ import (
type rpcServer struct{ svc *Service }
+// Metric represent single metric produced by the application.
type Metric struct {
// Collector name.
Name string
@@ -71,6 +72,63 @@ func (rpc *rpcServer) Add(m *Metric, ok *bool) error {
return nil
}
+// Sub subtract the value from the specific metric (gauge only).
+func (rpc *rpcServer) Sub(m *Metric, ok *bool) error {
+ c := rpc.svc.Collector(m.Name)
+ if c == nil {
+ return fmt.Errorf("undefined collector `%s`", m.Name)
+ }
+
+ switch c.(type) {
+ case prometheus.Gauge:
+ c.(prometheus.Gauge).Sub(m.Value)
+
+ case *prometheus.GaugeVec:
+ if len(m.Labels) == 0 {
+ return fmt.Errorf("required labels for collector `%s`", m.Name)
+ }
+
+ c.(*prometheus.GaugeVec).WithLabelValues(m.Labels...).Sub(m.Value)
+ default:
+ return fmt.Errorf("collector `%s` does not support method `Sub`", m.Name)
+ }
+
+ *ok = true
+ return nil
+}
+
+// Observe the value (histogram and summary only).
+func (rpc *rpcServer) Observe(m *Metric, ok *bool) error {
+ c := rpc.svc.Collector(m.Name)
+ if c == nil {
+ return fmt.Errorf("undefined collector `%s`", m.Name)
+ }
+
+ switch c.(type) {
+ case *prometheus.SummaryVec:
+ if len(m.Labels) == 0 {
+ return fmt.Errorf("required labels for collector `%s`", m.Name)
+ }
+
+ c.(*prometheus.SummaryVec).WithLabelValues(m.Labels...).Observe(m.Value)
+
+ case prometheus.Histogram:
+ c.(prometheus.Histogram).Observe(m.Value)
+
+ case *prometheus.HistogramVec:
+ if len(m.Labels) == 0 {
+ return fmt.Errorf("required labels for collector `%s`", m.Name)
+ }
+
+ c.(*prometheus.HistogramVec).WithLabelValues(m.Labels...).Observe(m.Value)
+ default:
+ return fmt.Errorf("collector `%s` does not support method `Observe`", m.Name)
+ }
+
+ *ok = true
+ return nil
+}
+
// Set the metric value (only for gaude).
func (rpc *rpcServer) Set(m *Metric, ok *bool) error {
c := rpc.svc.Collector(m.Name)
@@ -90,7 +148,7 @@ func (rpc *rpcServer) Set(m *Metric, ok *bool) error {
c.(*prometheus.GaugeVec).WithLabelValues(m.Labels...).Set(m.Value)
default:
- return fmt.Errorf("collector `%s` is not `gauge` type", m.Name)
+ return fmt.Errorf("collector `%s` does not support method `Set`", m.Name)
}
*ok = true