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

Uploaded Python 3

File details

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

File metadata

  • Download URL: spakky_tracing-6.9.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.9.0.tar.gz
Algorithm Hash digest
SHA256 ad8f44e8c91282e7117d682bad3d943456602aa2dcfaa90cba384b27ad62c9a4
MD5 664246680ff37afefc459e3eccd929ea
BLAKE2b-256 ab578b6681451b16737a5ea2f3ecfa6187e18ab7c6ee2cb1176cc9deeab90f49

See more details on using hashes here.

Provenance

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

File metadata

  • Download URL: spakky_tracing-6.9.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.9.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2e1cf499f82829e57e3b7f85adae61917a149a0163ceab0439ac85c2430207a3
MD5 cf233234e15bebce496d02aab8f0c2af
BLAKE2b-256 f2c41fc603226c973a09abd50ef2b1f1577f15e608fb5a306eefb4a090646716

See more details on using hashes here.

Provenance

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