Skip to main content

OpenTelemetry GenAI Utils

Project description

The GenAI Utils package provides boilerplate and helpers to standardize instrumentation for Generative AI. It offers APIs to minimize the work needed to instrument GenAI libraries, while providing standardization for generating spans, metrics, and events.

Key Components

  • TelemetryHandler – manages LLM invocation lifecycles (spans, metrics, events)

  • LLMInvocation and message types (Text, Reasoning, Blob, etc.) – structured data model for GenAI interactions

  • CompletionHook – protocol for uploading content to external storage (built-in fsspec support)

  • Metrics – gen_ai.client.operation.duration and gen_ai.client.token.usage histograms

Usage

See the module docstring in opentelemetry.util.genai.handler for usage examples, including context manager and manual lifecycle patterns.

Environment Variables

This package relies on environment variables to configure capturing of message content. By default, message content will not be captured. Set the environment variable OTEL_SEMCONV_STABILITY_OPT_IN to gen_ai_latest_experimental to enable experimental features. Set the environment variable OTEL_INSTRUMENTATION_GENAI_CAPTURE_MESSAGE_CONTENT to one of:

  • NO_CONTENT: Do not capture message content (default).

  • SPAN_ONLY: Capture message content in spans only.

  • EVENT_ONLY: Capture message content in events only.

  • SPAN_AND_EVENT: Capture message content in both spans and events.

To control event emission, you can optionally set OTEL_INSTRUMENTATION_GENAI_EMIT_EVENT to true or false (case-insensitive). This variable controls whether to emit gen_ai.client.inference.operation.details events. If not explicitly set, the default value is automatically determined by OTEL_INSTRUMENTATION_GENAI_CAPTURE_MESSAGE_CONTENT:

  • When NO_CONTENT or SPAN_ONLY is set: defaults to false

  • When EVENT_ONLY or SPAN_AND_EVENT is set: defaults to true

If explicitly set, the user’s value takes precedence over the default.

When EVENT_ONLY or SPAN_AND_EVENT mode is enabled and a LoggerProvider is configured, the package also emits gen_ai.client.inference.operation.details events with structured message content (as dictionaries instead of JSON strings). Note that when using EVENT_ONLY or SPAN_AND_EVENT, the OTEL_INSTRUMENTATION_GENAI_EMIT_EVENT environment variable defaults to true, so events will be emitted automatically unless explicitly set to false.

Completion Hook / Upload

  • OTEL_INSTRUMENTATION_GENAI_COMPLETION_HOOK: Name of the completion hook entry point to load (e.g. upload).

  • OTEL_INSTRUMENTATION_GENAI_UPLOAD_BASE_PATH: An fsspec-compatible URI/path for uploading prompts and completions (e.g. /path/to/prompts or gs://my_bucket). Required when using the upload hook.

  • OTEL_INSTRUMENTATION_GENAI_UPLOAD_FORMAT: Format for uploaded data – json (default) or jsonl.

  • OTEL_INSTRUMENTATION_GENAI_UPLOAD_MAX_QUEUE_SIZE: Maximum number of concurrent uploads to queue (default: 20).

Span Attributes

This package sets the following span attributes on LLM invocations:

Common attributes:

  • gen_ai.operation.name: Str(chat)

  • gen_ai.provider.name: Str(openai)

  • gen_ai.request.model: Str(gpt-4o)

  • server.address: Str(api.openai.com)

  • server.port: Int(443)

Response attributes:

  • gen_ai.response.finish_reasons: Slice([“stop”])

  • gen_ai.response.model: Str(gpt-4o-2024-05-13)

  • gen_ai.response.id: Str(chatcmpl-Bz8yrvPnydD9pObv625n2CGBPHS13)

  • gen_ai.usage.input_tokens: Int(24)

  • gen_ai.usage.output_tokens: Int(7)

Request parameter attributes (when provided):

  • gen_ai.request.temperature: Float(0.7)

  • gen_ai.request.top_p: Float(1.0)

  • gen_ai.request.frequency_penalty: Float(0.0)

  • gen_ai.request.presence_penalty: Float(0.0)

  • gen_ai.request.max_tokens: Int(1024)

  • gen_ai.request.stop_sequences: Slice([”\n”])

  • gen_ai.request.seed: Int(42)

Content attributes (sensitive, requires content capturing enabled):

  • gen_ai.input.messages: Str(‘[{“role”: “user”, “parts”: [{“content”: “hello world”, “type”: “text”}]}]’)

  • gen_ai.output.messages: Str(‘[{“role”: “assistant”, “parts”: [{“content”: “hello back”, “type”: “text”}], “finish_reason”: “stop”}]’)

  • gen_ai.system_instructions: Str(‘[{“content”: “You are a helpful assistant.”, “type”: “text”}]’)

Error attributes:

  • error.type: Str(TimeoutError)

Embedding Span Attributes

This package also supports embedding invocation spans via the embedding context manager. For embedding invocations, the following attributes are set:

Common attributes:

  • gen_ai.operation.name: Str(embeddings)

  • gen_ai.provider.name: Str(openai)

  • server.address: Str(api.openai.com)

  • server.port: Int(443)

Request attributes:

  • gen_ai.request.model: Str(text-embedding-3-small)

  • gen_ai.embeddings.dimension.count: Int(1536)

  • gen_ai.request.encoding_formats: Slice([“float”])

Response attributes:

  • gen_ai.response.model: Str(text-embedding-3-small)

  • gen_ai.usage.input_tokens: Int(24)

Installation

pip install opentelemetry-util-genai

For upload support (requires fsspec):

pip install opentelemetry-util-genai[upload]

Design Document

The design document for the OpenTelemetry GenAI Utils can be found at: Design Document

References

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

opentelemetry_util_genai-0.4b0.tar.gz (47.4 kB view details)

Uploaded Source

Built Distribution

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

opentelemetry_util_genai-0.4b0-py3-none-any.whl (42.8 kB view details)

Uploaded Python 3

File details

Details for the file opentelemetry_util_genai-0.4b0.tar.gz.

File metadata

  • Download URL: opentelemetry_util_genai-0.4b0.tar.gz
  • Upload date:
  • Size: 47.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.20

File hashes

Hashes for opentelemetry_util_genai-0.4b0.tar.gz
Algorithm Hash digest
SHA256 0235b03c5b3cb5efe5d3c16a5a68e82be34e6530d6707cf1cf122413578c2036
MD5 ffa9c29889448d778fffaba17a261abb
BLAKE2b-256 e854545527aba649f6b8aba7b70c855db9089a2b8f234bd6c19beffa73a3163d

See more details on using hashes here.

File details

Details for the file opentelemetry_util_genai-0.4b0-py3-none-any.whl.

File metadata

File hashes

Hashes for opentelemetry_util_genai-0.4b0-py3-none-any.whl
Algorithm Hash digest
SHA256 ac26db52ad1d86ce3e4ac183f204c37a6e66fdb6d86b71feee60468bcb32ef13
MD5 dc12f7a53eef37e68f9f420f3562663b
BLAKE2b-256 e8500b86c4159a74802a917fcc2adf22f1af522f03805cc049415221207249e8

See more details on using hashes here.

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