> 백엔드 개발 > Golang > 분산 시스템의 문자열 TraceID에서 OpenTelemetry 범위를 생성하는 방법은 무엇입니까?

분산 시스템의 문자열 TraceID에서 OpenTelemetry 범위를 생성하는 방법은 무엇입니까?

DDD
풀어 주다: 2024-10-29 06:28:02
원래의
1104명이 탐색했습니다.

How to Create OpenTelemetry Spans from a String TraceID in a Distributed System?

문자열 TraceID에서 OpenTelemetry 범위 생성

분산 시스템을 다룰 때 구성 요소 전체에서 컨텍스트를 유지하고 관계를 추적하는 것이 중요합니다. 이 경우 게시자가 메시지 헤더를 사용하여 추적 정보를 전파하는 경우 수신된 TraceID 문자열을 사용하여 구독자 측에서 OpenTelemetry 범위를 계속 구성할 수 있습니다.

헤더 값에서 SpanContext 구성

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로 새 범위 만들기

새 범위를 만들려면 이렇게 구성된 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿