mirror of
				https://github.com/zitadel/zitadel.git
				synced 2025-10-24 21:58:50 +00:00 
			
		
		
		
	fix(tracing): from opencensus to opentelemetry (#937)
* refactor: switch from opencensus to opentelemetry * tempo works as designed nooooot * fix: log traceids * with grafana agent * fix: http tracing * fix: cleanup files * chore: remove todo * fix: bad test * fix: ignore methods in grpc interceptors * fix: remove test log * clean up * typo * fix(config): configure tracing endpoint * fix(span): add error id to span
This commit is contained in:
		| @@ -4,45 +4,30 @@ import ( | ||||
| 	"context" | ||||
| 	"strings" | ||||
|  | ||||
| 	"go.opencensus.io/plugin/ocgrpc" | ||||
| 	"go.opencensus.io/trace" | ||||
| 	"google.golang.org/grpc" | ||||
| 	"google.golang.org/grpc/stats" | ||||
|  | ||||
| 	grpc_utils "github.com/caos/zitadel/internal/api/grpc" | ||||
| 	"github.com/caos/zitadel/internal/tracing" | ||||
| 	grpc_trace "go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc" | ||||
| 	"google.golang.org/grpc" | ||||
| ) | ||||
|  | ||||
| type GRPCMethod string | ||||
|  | ||||
| func TracingStatsServer(ignoredMethods ...GRPCMethod) grpc.ServerOption { | ||||
| 	return grpc.StatsHandler( | ||||
| 		&tracingServerHandler{ | ||||
| 			ignoredMethods, | ||||
| 			ocgrpc.ServerHandler{ | ||||
| 				StartOptions: trace.StartOptions{ | ||||
| 					Sampler:  tracing.Sampler(), | ||||
| 					SpanKind: trace.SpanKindServer, | ||||
| 				}, | ||||
| 			}, | ||||
| 		}, | ||||
| 	) | ||||
| func DefaultTracingServer() grpc.UnaryServerInterceptor { | ||||
| 	return TracingServer(grpc_utils.Healthz, grpc_utils.Readiness, grpc_utils.Validation) | ||||
| } | ||||
|  | ||||
| func DefaultTracingStatsServer() grpc.ServerOption { | ||||
| 	return TracingStatsServer(grpc_utils.Healthz, grpc_utils.Readiness, grpc_utils.Validation) | ||||
| } | ||||
| func TracingServer(ignoredMethods ...GRPCMethod) grpc.UnaryServerInterceptor { | ||||
| 	return func( | ||||
| 		ctx context.Context, | ||||
| 		req interface{}, | ||||
| 		info *grpc.UnaryServerInfo, | ||||
| 		handler grpc.UnaryHandler, | ||||
| 	) (interface{}, error) { | ||||
|  | ||||
| type tracingServerHandler struct { | ||||
| 	IgnoredMethods []GRPCMethod | ||||
| 	ocgrpc.ServerHandler | ||||
| } | ||||
|  | ||||
| func (s *tracingServerHandler) TagRPC(ctx context.Context, tagInfo *stats.RPCTagInfo) context.Context { | ||||
| 	for _, method := range s.IgnoredMethods { | ||||
| 		if strings.HasSuffix(tagInfo.FullMethodName, string(method)) { | ||||
| 			return ctx | ||||
| 		for _, ignoredMethod := range ignoredMethods { | ||||
| 			if strings.HasSuffix(info.FullMethod, string(ignoredMethod)) { | ||||
| 				return handler(ctx, req) | ||||
| 			} | ||||
| 		} | ||||
| 		return grpc_trace.UnaryServerInterceptor()(ctx, req, info, handler) | ||||
| 	} | ||||
| 	return s.ServerHandler.TagRPC(ctx, tagInfo) | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Silvan
					Silvan