Documentation ¶
Overview ¶
Package zerolog provides a small adapter required to use zerolog in logging gRPC middlewares. Please see examples for examples of use.
Example (InitializationWithCustomLevels) ¶
package main import ( "os" grpczerolog "github.com/grpc-ecosystem/go-grpc-middleware/providers/zerolog" "github.com/grpc-ecosystem/go-grpc-middleware/v2/interceptors/logging" "github.com/rs/zerolog" "google.golang.org/grpc" ) var customFunc logging.CodeToLevel func main() { // Logger is used, allowing pre-definition of certain fields by the user. logger := zerolog.New(os.Stderr) // Shared options for the logger, with a custom gRPC code to log level function. opts := []logging.Option{ logging.WithLevels(customFunc), } // Create a server, make sure we put the tags context before everything else. _ = grpc.NewServer( grpc.ChainUnaryInterceptor( logging.UnaryServerInterceptor(grpczerolog.InterceptorLogger(logger), opts...), ), grpc.ChainStreamInterceptor( logging.StreamServerInterceptor(grpczerolog.InterceptorLogger(logger), opts...), ), ) }
Output:
Example (InitializationWithDurationFieldOverride) ¶
package main import ( "os" grpczerolog "github.com/grpc-ecosystem/go-grpc-middleware/providers/zerolog" "github.com/grpc-ecosystem/go-grpc-middleware/v2/interceptors/logging" "github.com/rs/zerolog" "google.golang.org/grpc" ) var customDurationToFields logging.DurationToFields func main() { // Logger is used, allowing pre-definition of certain fields by the user. logger := zerolog.New(os.Stderr) // Shared options for the logger, with a custom duration to log field function. opts := []logging.Option{ logging.WithDurationField(customDurationToFields), } // Create a server, make sure we put the tags context before everything else. _ = grpc.NewServer( grpc.ChainUnaryInterceptor( logging.UnaryServerInterceptor(grpczerolog.InterceptorLogger(logger), opts...), ), grpc.ChainStreamInterceptor( logging.StreamServerInterceptor(grpczerolog.InterceptorLogger(logger), opts...), ), ) }
Output:
Index ¶
Examples ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
Click to show internal directories.
Click to hide internal directories.