44 lines
1.3 KiB
Go

// Copyright (c) 2020 Gitpod GmbH. All rights reserved.
// Licensed under the GNU Affero General Public License (AGPL).
// See License-AGPL.txt in the project root for license information.
package grpc
import (
"context"
"github.com/prometheus/client_golang/prometheus"
"google.golang.org/grpc"
"google.golang.org/grpc/codes"
"google.golang.org/grpc/status"
)
// NewUnaryCallMetricsInterceptor creates a new unary interceptor that provides call counts
// and error rate metrics.
func NewUnaryCallMetricsInterceptor(reg prometheus.Registerer) (grpc.UnaryServerInterceptor, error) {
const (
labelMethod = "method"
labelResponse = "response"
)
callCountVec := prometheus.NewCounterVec(prometheus.CounterOpts{
Name: "grpc_call_total",
Help: "total calls per function",
}, []string{labelMethod, labelResponse})
err := reg.Register(callCountVec)
if err != nil {
return nil, err
}
return func(ctx context.Context, req interface{}, info *grpc.UnaryServerInfo, handler grpc.UnaryHandler) (resp interface{}, err error) {
resp, err = handler(ctx, req)
code := codes.OK
if s, ok := status.FromError(err); ok {
code = s.Code()
}
callCountVec.With(prometheus.Labels{labelMethod: info.FullMethod, labelResponse: code.String()}).Inc()
return
}, nil
}