tracinginterceptor.go 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  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 func that handles tracing with given service name.
  9. func UnaryTracingInterceptor(serviceName string) grpc.UnaryServerInterceptor {
  10. return func(ctx context.Context, req interface{}, info *grpc.UnaryServerInfo,
  11. handler grpc.UnaryHandler) (resp interface{}, err error) {
  12. md, ok := metadata.FromIncomingContext(ctx)
  13. if !ok {
  14. return handler(ctx, req)
  15. }
  16. carrier, err := trace.Extract(trace.GrpcFormat, md)
  17. if err != nil {
  18. return handler(ctx, req)
  19. }
  20. ctx, span := trace.StartServerSpan(ctx, carrier, serviceName, info.FullMethod)
  21. defer span.Finish()
  22. return handler(ctx, req)
  23. }
  24. }
  25. func StreamTracingInterceptor(serviceName string) grpc.StreamServerInterceptor {
  26. return func(srv interface{}, ss grpc.ServerStream, info *grpc.StreamServerInfo,
  27. handler grpc.StreamHandler) error {
  28. ctx := ss.Context()
  29. md, ok := metadata.FromIncomingContext(ctx)
  30. if !ok {
  31. return handler(srv, ss)
  32. }
  33. carrier, err := trace.Extract(trace.GrpcFormat, md)
  34. if err != nil {
  35. return handler(srv, ss)
  36. }
  37. ctx, span := trace.StartServerSpan(ctx, carrier, serviceName, info.FullMethod)
  38. defer span.Finish()
  39. return handler(srv, ss)
  40. }
  41. }