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.7.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.7.0-py3-none-any.whl (7.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: spakky_tracing-6.7.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.7.0.tar.gz
Algorithm Hash digest
SHA256 f0c8f24ebde334d1cfbede26c6cd514c0146f55d9c47fb987dd1ae068c626410
MD5 94410bc469eecbb362e77d280a80f604
BLAKE2b-256 bd02c3d383d766611bbe4daf1649d72655135821194dbed428fb67ade5f42427

See more details on using hashes here.

Provenance

The following attestation bundles were made for spakky_tracing-6.7.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.7.0-py3-none-any.whl.

File metadata

  • Download URL: spakky_tracing-6.7.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.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d1f98593e3265c000b64274f6ad3e688b2a6bd438eb12b106b40e30a7d8b1d58
MD5 908d1aeb6df6cd1de43fb427ac822494
BLAKE2b-256 5bc906ead56c2ba22f5e3e9b10403cbe5771ba9edb298743abd9d54475c483d7

See more details on using hashes here.

Provenance

The following attestation bundles were made for spakky_tracing-6.7.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