분산 시스템을 다룰 때 구성 요소 전체에서 컨텍스트를 유지하고 관계를 추적하는 것이 중요합니다. 이 경우 게시자가 메시지 헤더를 사용하여 추적 정보를 전파하는 경우 수신된 TraceID 문자열을 사용하여 구독자 측에서 OpenTelemetry 범위를 계속 구성할 수 있습니다.
To 상위 항목이 올바르게 링크된 범위를 생성하려면 요청 헤더에서 추출된 추적 ID 및 범위 ID 문자열을 추적.TraceID 및 추적.SpanID 개체로 변환해야 합니다. 다음 함수를 사용하여 이를 달성합니다.
<code class="go">var traceID trace.TraceID traceID, err = trace.TraceIDFromHex(request.TraceID) var spanID trace.SpanID spanID, err = trace.SpanIDFromHex(request.SpanID)</code>
traceID 및spanID 개체를 사용하여 SpanContext를 구성할 수 있습니다. Remote 플래그를 false로 설정해야 합니다. 이는 이 범위가 원격 시스템으로 내보내지지 않음을 나타냅니다.
<code class="go">var spanContextConfig trace.SpanContextConfig spanContextConfig.TraceID = traceID spanContextConfig.SpanID = spanID spanContextConfig.TraceFlags = 01 spanContextConfig.Remote = false spanContext = trace.NewSpanContext(spanContextConfig)</code>
새 범위를 만들려면 이렇게 구성된 SpanContext를 사용하여 먼저 새 컨텍스트를 강화해야 합니다.
<code class="go">requestContext := context.Background() requestContext = trace.ContextWithSpanContext(requestContext, spanContext)</code>
그런 다음 강화된 컨텍스트를 사용하여 새 하위 범위를 시작할 수 있습니다.
<code class="go">var requestInLoopSpan trace.Span childContext, requestInLoopSpan := otel.Tracer("inboundmessage").Start(requestContext, "requestInLoopSpan")</code>
이 하위 스팬은 게시자 측의 상위 스팬에 연결되어 분산 시스템 전반에 걸쳐 적절한 컨텍스트 전파가 가능해집니다.
위 내용은 분산 시스템의 문자열 TraceID에서 OpenTelemetry 범위를 생성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!