OpenAI Monitoring with OpenTelemetry

SigNoz Cloud - This page applies to SigNoz Cloud editions.
Self-Host - This page applies to self-hosted SigNoz editions.

This guide walks you through setting up OpenAI monitoring using OpenTelemetry and SigNoz. You will instrument your OpenAI applications to capture traces, logs, and metrics and visualize them in real time in SigNoz.

OpenAI monitoring with SigNoz gives you visibility into:

  • Token usage — track input and output tokens per request to understand cost drivers
  • Model latency — measure response times across models and request types
  • Error rates — detect API failures, rate limit errors, and timeouts before they impact users
  • Request traces — follow individual LLM calls through your full application stack

Requirements

  • Python 3.8 or newer
  • OpenAI Python library (openai >= 1.0.0)
  • Valid OpenAI API key
  • SigNoz setup (choose one):

Setup

Step 1. Create a virtual environment

python3 -m venv .venv
source .venv/bin/activate

Step 2. Install the OpenTelemetry dependencies

pip install opentelemetry-distro~=0.51b0
pip install opentelemetry-exporter-otlp~=1.30.0
pip install opentelemetry-instrumentation-openai-v2

Step 3. Add automatic instrumentation

opentelemetry-bootstrap --action=install

Step 4. Run your application

OTEL_SERVICE_NAME=<service-name> \
OTEL_EXPORTER_OTLP_ENDPOINT="https://ingest.<region>.signoz.cloud:443" \
OTEL_EXPORTER_OTLP_HEADERS="signoz-ingestion-key=<your-ingestion-key>" \
OTEL_EXPORTER_OTLP_PROTOCOL=grpc \
OTEL_PYTHON_LOGGING_AUTO_INSTRUMENTATION_ENABLED=true \
OTEL_INSTRUMENTATION_GENAI_CAPTURE_MESSAGE_CONTENT=true \
OPENAI_API_KEY=<your-openai-key> \
opentelemetry-instrument <your_run_command>

Environment Variables Explained:

  • OTEL_PYTHON_LOGGING_AUTO_INSTRUMENTATION_ENABLED - Enables automatic logging instrumentation

  • OTEL_INSTRUMENTATION_GENAI_CAPTURE_MESSAGE_CONTENT - Captures prompts and completions as logs

  • <region>: Your SigNoz Cloud region

  • <your-ingestion-key>: Your SigNoz ingestion key

  • Replace <service-name> with the name of your service

  • Replace <your-openai-key> with your OpenAI API key

Using self-hosted SigNoz? Most steps are identical. To adapt this guide, update the endpoint and remove the ingestion key header as shown in Cloud → Self-Hosted.

What Does OpenAI Monitoring Capture?

This instrumentation captures comprehensive telemetry data for your OpenAI applications:

Traces

  • Spans for each OpenAI API call with timing information
  • Operation details like model name, max tokens etc.
  • Token usage including input and output
  • Request and response metadata such as finish reason and model used

Logs

  • Structured logs for each API call when OTEL_PYTHON_LOGGING_AUTO_INSTRUMENTATION_ENABLED=true is set
  • Message content logs (prompts and completions) when OTEL_INSTRUMENTATION_GENAI_CAPTURE_MESSAGE_CONTENT=true is enabled
  • Error logs for failed API calls with detailed error information and stack traces
  • Performance logs showing request duration and timing information

Log Levels and Content:

  • INFO level logs for successful API calls with metadata
  • ERROR level logs for failed requests with error details
  • DEBUG level logs for detailed request/response information (when debug logging is enabled)

Metrics

  • Duration metrics showing how long OpenAI calls take
  • Token usage metrics tracking consumption over time
  • Request rate metrics showing API call frequency
  • Error rate metrics for monitoring API failures

More details about the metrics can be found here.

Validating Your OpenAI Monitoring Setup

Validate your traces, logs, and metrics in SigNoz:

  • Trigger OpenAI API calls in your app. Make several API calls to generate some data. Then, wait for some time.
  • In SigNoz, open the Services tab. Hit the Refresh button on the top right corner, and your application should appear in the list of Applications.
  • Go to the Traces tab, and apply relevant filters to see your application's traces.
  • Check the Logs tab to see captured logs from your OpenAI calls.
  • Visit the Metrics tab to view token usage and performance metrics.
OpenAI monitoring traces in SigNoz showing span details and token usage
OpenAI request traces in SigNoz
OpenAI application logs captured in SigNoz via OpenTelemetry
OpenAI API logs in SigNoz
OpenAI monitoring metrics in SigNoz showing token usage and latency
OpenAI API metrics in SigNoz

Capturing Message Content (Optional)

By default, message content such as prompts and completions are not captured. To capture message content as log events, set the environment variable:

export OTEL_INSTRUMENTATION_GENAI_CAPTURE_MESSAGE_CONTENT=true

Note: Be cautious when enabling this in production as it may capture sensitive user data. This feature is already included in the run command above.

Troubleshooting your installation

Spans are not being reported

If spans are not being reported to SigNoz, try enabling debug exporter which writes the JSON formatted trace data to the console by setting env var OTEL_TRACES_EXPORTER=console.

OTEL_SERVICE_NAME=my-openai-app \
OTEL_TRACES_EXPORTER=console \
opentelemetry-instrument python app.py

You should see trace data in your console output that looks like:

{
  "name": "chat_completions_create",
  "context": {
    "trace_id": "0xedb7caf0c8b082a9578460a201759193",
    "span_id": "0x57cf7eee198e1fed",
    "trace_state": "[]"
  },
  "kind": "SpanKind.CLIENT",
  "parent_id": null,
  "start_time": "2025-01-15T10:30:00.804758Z",
  "end_time": "2025-01-15T10:30:01.204805Z",
  "status": {
    "status_code": "UNSET"
  },
  "attributes": {
    "gen_ai.system": "openai",
    "gen_ai.request.model": "gpt-4o-mini",
    "gen_ai.usage.total_tokens": 150
  },
  "events": [],
  "links": [],
  "resource": {
    "telemetry.sdk.language": "python",
    "telemetry.sdk.name": "opentelemetry",
    "telemetry.sdk.version": "1.30.0",
    "service.name": "my-openai-app"
  }
}

Common Issues

If you don't see your telemetry data:

  1. Check your OpenAI API key - Make sure OPENAI_API_KEY environment variable is set
  2. Verify network connectivity - Ensure your application can reach SigNoz Cloud endpoints
  3. Check ingestion key - Verify your SigNoz ingestion key is correct
  4. Wait for data - OpenTelemetry batches data before sending, so wait 10-30 seconds after making API calls

OpenAI Monitoring Dashboard

You can also check out our custom OpenAI dashboard here which provides specialized visualizations for monitoring your OpenAI usage in applications. The dashboard includes pre-built charts specifically tailored for LLM usage, along with import instructions to get started quickly.

OpenAI monitoring dashboard in SigNoz with pre-built LLM charts
OpenAI monitoring dashboard in SigNoz

Last updated: May 24, 2026

Edit on GitHub

Was this page helpful?

Your response helps us improve this page.