tracinginterceptor.go 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. package serverinterceptors
  2. import (
  3. "context"
  4. "github.com/tal-tech/go-zero/core/trace"
  5. "google.golang.org/grpc"
  6. "google.golang.org/grpc/metadata"
  7. )
  8. // UnaryTracingInterceptor returns a grpc.UnaryServerInterceptor
  9. // that handles tracing with given service name.
  10. func UnaryTracingInterceptor(serviceName string) grpc.UnaryServerInterceptor {
  11. return func(ctx context.Context, req interface{}, info *grpc.UnaryServerInfo,
  12. handler grpc.UnaryHandler) (resp interface{}, err error) {
  13. md, ok := metadata.FromIncomingContext(ctx)
  14. if !ok {
  15. return handler(ctx, req)
  16. }
  17. carrier, err := trace.Extract(trace.GrpcFormat, md)
  18. if err != nil {
  19. return handler(ctx, req)
  20. }
  21. ctx, span := trace.StartServerSpan(ctx, carrier, serviceName, info.FullMethod)
  22. defer span.Finish()
  23. return handler(ctx, req)
  24. }
  25. }
  26. // StreamTracingInterceptor returns a grpc.StreamServerInterceptor
  27. // that handles tracing with given service name.
  28. func StreamTracingInterceptor(serviceName string) grpc.StreamServerInterceptor {
  29. return func(srv interface{}, ss grpc.ServerStream, info *grpc.StreamServerInfo,
  30. handler grpc.StreamHandler) error {
  31. ctx := ss.Context()
  32. md, ok := metadata.FromIncomingContext(ctx)
  33. if !ok {
  34. return handler(srv, ss)
  35. }
  36. carrier, err := trace.Extract(trace.GrpcFormat, md)
  37. if err != nil {
  38. return handler(srv, ss)
  39. }
  40. _, span := trace.StartServerSpan(ctx, carrier, serviceName, info.FullMethod)
  41. defer span.Finish()
  42. return handler(srv, ss)
  43. }
  44. }