mirror of
https://github.com/netbirdio/netbird.git
synced 2025-01-07 14:39:10 +01:00
77 lines
2.6 KiB
Go
77 lines
2.6 KiB
Go
|
package telemetry
|
||
|
|
||
|
import (
|
||
|
"context"
|
||
|
"go.opentelemetry.io/otel/metric"
|
||
|
"go.opentelemetry.io/otel/metric/instrument"
|
||
|
"go.opentelemetry.io/otel/metric/instrument/asyncint64"
|
||
|
"go.opentelemetry.io/otel/metric/instrument/syncint64"
|
||
|
)
|
||
|
|
||
|
// GRPCMetrics are gRPC server metrics
|
||
|
type GRPCMetrics struct {
|
||
|
meter metric.Meter
|
||
|
syncRequestsCounter syncint64.Counter
|
||
|
loginRequestsCounter syncint64.Counter
|
||
|
getKeyRequestsCounter syncint64.Counter
|
||
|
activeStreamsGauge asyncint64.Gauge
|
||
|
ctx context.Context
|
||
|
}
|
||
|
|
||
|
// NewGRPCMetrics creates new GRPCMetrics struct and registers common metrics of the gRPC server
|
||
|
func NewGRPCMetrics(ctx context.Context, meter metric.Meter) (*GRPCMetrics, error) {
|
||
|
syncRequestsCounter, err := meter.SyncInt64().Counter("management.grpc.sync.request.counter", instrument.WithUnit("1"))
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
loginRequestsCounter, err := meter.SyncInt64().Counter("management.grpc.login.request.counter", instrument.WithUnit("1"))
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
getKeyRequestsCounter, err := meter.SyncInt64().Counter("management.grpc.key.request.counter", instrument.WithUnit("1"))
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
|
||
|
activeStreamsGauge, err := meter.AsyncInt64().Gauge("management.grpc.connected.streams", instrument.WithUnit("1"))
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
|
||
|
return &GRPCMetrics{
|
||
|
meter: meter,
|
||
|
syncRequestsCounter: syncRequestsCounter,
|
||
|
loginRequestsCounter: loginRequestsCounter,
|
||
|
getKeyRequestsCounter: getKeyRequestsCounter,
|
||
|
activeStreamsGauge: activeStreamsGauge,
|
||
|
ctx: ctx,
|
||
|
}, err
|
||
|
}
|
||
|
|
||
|
// CountSyncRequest counts the number of gRPC sync requests coming to the gRPC API
|
||
|
func (grpcMetrics *GRPCMetrics) CountSyncRequest() {
|
||
|
grpcMetrics.syncRequestsCounter.Add(grpcMetrics.ctx, 1)
|
||
|
}
|
||
|
|
||
|
// CountGetKeyRequest counts the number of gRPC get server key requests coming to the gRPC API
|
||
|
func (grpcMetrics *GRPCMetrics) CountGetKeyRequest() {
|
||
|
grpcMetrics.getKeyRequestsCounter.Add(grpcMetrics.ctx, 1)
|
||
|
}
|
||
|
|
||
|
// CountLoginRequest counts the number of gRPC login requests coming to the gRPC API
|
||
|
func (grpcMetrics *GRPCMetrics) CountLoginRequest() {
|
||
|
grpcMetrics.loginRequestsCounter.Add(grpcMetrics.ctx, 1)
|
||
|
}
|
||
|
|
||
|
// RegisterConnectedStreams registers a function that collects number of active streams and feeds it to the metrics gauge.
|
||
|
func (grpcMetrics *GRPCMetrics) RegisterConnectedStreams(producer func() int64) error {
|
||
|
return grpcMetrics.meter.RegisterCallback(
|
||
|
[]instrument.Asynchronous{
|
||
|
grpcMetrics.activeStreamsGauge,
|
||
|
},
|
||
|
func(ctx context.Context) {
|
||
|
grpcMetrics.activeStreamsGauge.Observe(ctx, producer())
|
||
|
},
|
||
|
)
|
||
|
}
|