 f9212348e4
			
		
	
	f9212348e4
	
	
	
		
			
			This provideds generic grpc metrics via prometheus Signed-off-by: Michael Crosby <crosbymichael@gmail.com>
		
			
				
	
	
		
			73 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2016 Michal Witkowski. All Rights Reserved.
 | |
| // See LICENSE for licensing terms.
 | |
| 
 | |
| // gRPC Prometheus monitoring interceptors for client-side gRPC.
 | |
| 
 | |
| package grpc_prometheus
 | |
| 
 | |
| import (
 | |
| 	"io"
 | |
| 
 | |
| 	"golang.org/x/net/context"
 | |
| 	"google.golang.org/grpc"
 | |
| 	"google.golang.org/grpc/codes"
 | |
| )
 | |
| 
 | |
| // UnaryClientInterceptor is a gRPC client-side interceptor that provides Prometheus monitoring for Unary RPCs.
 | |
| func UnaryClientInterceptor(ctx context.Context, method string, req, reply interface{}, cc *grpc.ClientConn, invoker grpc.UnaryInvoker, opts ...grpc.CallOption) error {
 | |
| 	monitor := newClientReporter(Unary, method)
 | |
| 	monitor.SentMessage()
 | |
| 	err := invoker(ctx, method, req, reply, cc, opts...)
 | |
| 	if err != nil {
 | |
| 		monitor.ReceivedMessage()
 | |
| 	}
 | |
| 	monitor.Handled(grpc.Code(err))
 | |
| 	return err
 | |
| }
 | |
| 
 | |
| // StreamServerInterceptor is a gRPC client-side interceptor that provides Prometheus monitoring for Streaming RPCs.
 | |
| func StreamClientInterceptor(ctx context.Context, desc *grpc.StreamDesc, cc *grpc.ClientConn, method string, streamer grpc.Streamer, opts ...grpc.CallOption) (grpc.ClientStream, error) {
 | |
| 	monitor := newClientReporter(clientStreamType(desc), method)
 | |
| 	clientStream, err := streamer(ctx, desc, cc, method, opts...)
 | |
| 	if err != nil {
 | |
| 		monitor.Handled(grpc.Code(err))
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	return &monitoredClientStream{clientStream, monitor}, nil
 | |
| }
 | |
| 
 | |
| func clientStreamType(desc *grpc.StreamDesc) grpcType {
 | |
| 	if desc.ClientStreams && !desc.ServerStreams {
 | |
| 		return ClientStream
 | |
| 	} else if !desc.ClientStreams && desc.ServerStreams {
 | |
| 		return ServerStream
 | |
| 	}
 | |
| 	return BidiStream
 | |
| }
 | |
| 
 | |
| // monitoredClientStream wraps grpc.ClientStream allowing each Sent/Recv of message to increment counters.
 | |
| type monitoredClientStream struct {
 | |
| 	grpc.ClientStream
 | |
| 	monitor *clientReporter
 | |
| }
 | |
| 
 | |
| func (s *monitoredClientStream) SendMsg(m interface{}) error {
 | |
| 	err := s.ClientStream.SendMsg(m)
 | |
| 	if err == nil {
 | |
| 		s.monitor.SentMessage()
 | |
| 	}
 | |
| 	return err
 | |
| }
 | |
| 
 | |
| func (s *monitoredClientStream) RecvMsg(m interface{}) error {
 | |
| 	err := s.ClientStream.RecvMsg(m)
 | |
| 	if err == nil {
 | |
| 		s.monitor.ReceivedMessage()
 | |
| 	} else if err == io.EOF {
 | |
| 		s.monitor.Handled(codes.OK)
 | |
| 	} else {
 | |
| 		s.monitor.Handled(grpc.Code(err))
 | |
| 	}
 | |
| 	return err
 | |
| }
 |