Skip to main content

Lightweight LLM tracing SDK with remote tool invocation

Project description

lightrace-python

Lightweight LLM tracing SDK for Python with remote tool invocation.

Install

pip install lightrace

Quick Start

from lightrace import Lightrace, trace

lt = Lightrace(
    public_key="pk-lt-demo",
    secret_key="sk-lt-demo",
    host="http://localhost:3002",
)

# Root trace
@trace()
def run_agent(query: str):
    return search(query)

# Span
@trace(type="span")
def search(query: str) -> list:
    return ["result1", "result2"]

# Generation (LLM call)
@trace(type="generation", model="gpt-4o")
def generate(prompt: str) -> str:
    return "LLM response"

# Tool — remotely invocable from the Lightrace UI
@trace(type="tool")
def weather_lookup(city: str) -> dict:
    return {"temp": 72, "unit": "F"}

# Tool — traced but NOT remotely invocable
@trace(type="tool", invoke=False)
def read_file(path: str) -> str:
    return open(path).read()

run_agent("hello")
lt.flush()
lt.shutdown()

@trace API

@trace()                                    # Root trace
@trace(type="span")                         # Span observation
@trace(type="generation", model="gpt-4o")   # LLM generation
@trace(type="tool")                         # Tool (remotely invocable)
@trace(type="tool", invoke=False)           # Tool (trace only)

Parameters

Parameter Type Default Description
type str None "span", "generation", "tool", "chain", "event"
name str None Override name (defaults to function name)
invoke bool True For type="tool": register for remote invocation
model str None For type="generation": LLM model name
metadata dict None Static metadata attached to every call

Compatibility

Lightrace server also accepts traces from Langfuse Python/JS SDKs.

Development

uv sync --extra dev
uv run pre-commit install
uv run pytest -s -v tests/
uv run ruff check .
uv run mypy src/lightrace

License

MIT

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

lightrace-0.1.2.tar.gz (116.2 kB view details)

Uploaded Source

Built Distribution

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

lightrace-0.1.2-py3-none-any.whl (21.0 kB view details)

Uploaded Python 3

File details

Details for the file lightrace-0.1.2.tar.gz.

File metadata

  • Download URL: lightrace-0.1.2.tar.gz
  • Upload date:
  • Size: 116.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for lightrace-0.1.2.tar.gz
Algorithm Hash digest
SHA256 fc964d03299d25719b1c6ff11962aa44f36cb6464070a3ac1c16bd2b817a97db
MD5 dbd2e74031dcb3e9e12c7a9a6e906201
BLAKE2b-256 3f0b5ecc9f9b9763635c92d6e7682d352941cec8efe0e2a921693cb610e9c09b

See more details on using hashes here.

Provenance

The following attestation bundles were made for lightrace-0.1.2.tar.gz:

Publisher: release.yml on SKE-Labs/lightrace-python

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

File details

Details for the file lightrace-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: lightrace-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 21.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for lightrace-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 54849f95d19457eaff85618d99148e7a8fc0cb2db7edf69d5fd3a231203d5279
MD5 1c03cc46f5432276c880437a7264bb01
BLAKE2b-256 944bcf71493a326adc8682108913d8f5de065e62fbb201a270859ee26b5a6a68

See more details on using hashes here.

Provenance

The following attestation bundles were made for lightrace-0.1.2-py3-none-any.whl:

Publisher: release.yml on SKE-Labs/lightrace-python

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