Skip to main content

Structured logging system for Spakky Framework

Project description

spakky-logging

Spakky Framework를 위한 구조화 로깅 시스템입니다. contextvars 기반 로그 컨텍스트 전파, 설정 가능한 formatter(Text, JSON, Pretty), AOP 기반 메서드 호출 로깅, PostProcessor 기반 자동 설정을 제공합니다.

설치

pip install spakky-logging

빠른 시작

1. 플러그인 자동 등록

spakky-loggingload_plugins()를 통해 자동으로 로드됩니다.

app = SpakkyApplication(ApplicationContext()).load_plugins().scan(my_app).start()

2. @logged로 메서드 표시

from spakky.plugins.logging import logged

class UserService:
    @logged()
    async def create_user(self, name: str, password: str) -> User:
        ...

3. 설정(선택)

LoggingConfig로 기본값을 override합니다.

LoggingConfig@Configuration Pod로 로드되며, pydantic-settings를 통해 SPAKKY_LOGGING__* 환경변수를 읽습니다.

export SPAKKY_LOGGING__LEVEL=10
export SPAKKY_LOGGING__FORMAT=json
export SPAKKY_LOGGING__MASK_KEYS='["password", "token", "secret"]'
export SPAKKY_LOGGING__SLOW_THRESHOLD_MS=500

4. LogContext 전파

모든 log record에 자동 포함될 contextual key-value pair를 바인딩합니다.

from spakky.plugins.logging import LogContext

LogContext.bind(request_id="req-123", user_id="u-456")

with LogContext.scope(trace_id="t-789"):
    # 이 block 안의 모든 log는 trace_id를 포함
    ...

주요 기능

기능 설명
@logged() annotation AOP 기반 method call/result/error 자동 logging
LogContext contextvars 기반 structured context 전파
ContextInjectingFilter 모든 LogRecord에 LogContext value 주입
SpakkyTextFormatter pipe로 구분된 text format
SpakkyJsonFormatter line당 JSON object 하나
SpakkyPrettyFormatter 개발용 ANSI color multi-column format
LoggingConfig 중앙 logging configuration용 @Configuration pod
LoggingSetupPostProcessor application start 시 root logger 자동 설정
민감 데이터 masking log output에서 password, token, secret 등을 masking
느린 호출 감지 method 실행 시간이 threshold를 넘으면 warning 출력
결과 truncation 긴 return value를 log output에서 잘라냄

라이선스

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_logging-6.6.1.tar.gz (10.4 kB view details)

Uploaded Source

Built Distribution

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

spakky_logging-6.6.1-py3-none-any.whl (15.9 kB view details)

Uploaded Python 3

File details

Details for the file spakky_logging-6.6.1.tar.gz.

File metadata

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

File hashes

Hashes for spakky_logging-6.6.1.tar.gz
Algorithm Hash digest
SHA256 b064aeca631d3902a16f0d34f8a8e5efe6bc688c8973a5bbf19c179d1da43255
MD5 96f5275b8c19e90707b90534455165de
BLAKE2b-256 ba6176e49e7ab7ea3ad974d100b560393069b920b4cf30d3f4fbc27d3647460f

See more details on using hashes here.

Provenance

The following attestation bundles were made for spakky_logging-6.6.1.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_logging-6.6.1-py3-none-any.whl.

File metadata

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

File hashes

Hashes for spakky_logging-6.6.1-py3-none-any.whl
Algorithm Hash digest
SHA256 cef2fccbf4242b0e46a661c65b6c24730cc190aed39058b30fbdd467cc268946
MD5 6f944d3b4d7e35d5e63ff73e47d20f22
BLAKE2b-256 9dcc3d5687ec4f23f6d6803b6b55241c092c23b3425eece8e58b932e20574b59

See more details on using hashes here.

Provenance

The following attestation bundles were made for spakky_logging-6.6.1-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