Skip to main content

Distributed tracing abstraction for Spakky Framework

Project description

Spakky Tracing

Spakky Framework를 위한 분산 트레이싱 추상화입니다. TraceContextITracePropagator로 HTTP, messaging, task boundary 사이의 trace metadata를 전달합니다.

설치

pip install spakky-tracing

주요 기능

  • TraceContext: contextvars를 지원하는 W3C Trace Context Level 2 호환 trace context
  • ITracePropagator: service boundary를 넘는 trace context propagation용 abstract interface
  • W3CTracePropagator: 내장 W3C traceparent header propagator
  • Async-safe: asyncio task별로 격리되는 contextvars 기반 context propagation
  • 외부 의존성 없음: 순수 Python 구현이며 spakky core에만 의존

빠른 시작

TraceContext 생성과 전파

from spakky.tracing.context import TraceContext

# 새 root trace 시작
ctx = TraceContext.new_root()
TraceContext.set(ctx)

# 현재 trace 접근
current = TraceContext.get()
print(current.to_traceparent())
# 00-0af7651916cd43dd8448eb211c80319c-b7ad6b7169203331-01

# child span 생성
child = current.child()
TraceContext.set(child)

들어오는 trace header 파싱

from spakky.tracing.context import TraceContext

header = "00-0af7651916cd43dd8448eb211c80319c-b7ad6b7169203331-01"
ctx = TraceContext.from_traceparent(header)

W3CTracePropagator로 주입/추출

from spakky.tracing.w3c_propagator import W3CTracePropagator

propagator = W3CTracePropagator()

# 현재 trace를 outgoing header에 주입
carrier: dict[str, str] = {}
propagator.inject(carrier)
# carrier == {"traceparent": "00-...-...-01"}

# incoming header에서 trace 추출
ctx = propagator.extract(carrier)

라이선스

MIT License

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

spakky_tracing-6.8.0.tar.gz (4.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

spakky_tracing-6.8.0-py3-none-any.whl (7.3 kB view details)

Uploaded Python 3

File details

Details for the file spakky_tracing-6.8.0.tar.gz.

File metadata

  • Download URL: spakky_tracing-6.8.0.tar.gz
  • Upload date:
  • Size: 4.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for spakky_tracing-6.8.0.tar.gz
Algorithm Hash digest
SHA256 773c14252100cb8830a3e0d56af8bbbf66835a2bf132240d163cbb78e20820a2
MD5 97cacfa08f832209da9b2079897a18ed
BLAKE2b-256 488b53a2e1ddabd402a45b926afef61e1bfaa661883d5152284123b02e957f66

See more details on using hashes here.

Provenance

The following attestation bundles were made for spakky_tracing-6.8.0.tar.gz:

Publisher: release.yml on E5presso/spakky-framework

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file spakky_tracing-6.8.0-py3-none-any.whl.

File metadata

  • Download URL: spakky_tracing-6.8.0-py3-none-any.whl
  • Upload date:
  • Size: 7.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for spakky_tracing-6.8.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ded0238e5f3020c590160a63806cc9734691da0f3faa4519e5e208c4a4791b1a
MD5 5d80694d52411230915a87d4626a84b4
BLAKE2b-256 54c28786b515a787b9f807379f5234b13b8cecb977398f3fa574bcbd9389737f

See more details on using hashes here.

Provenance

The following attestation bundles were made for spakky_tracing-6.8.0-py3-none-any.whl:

Publisher: release.yml on E5presso/spakky-framework

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page