apps/opik-documentation/documentation/fern/docs/tracing/integrations/pipecat.mdx
Pipecat is an open-source Python framework for building real-time voice and multimodal conversational AI agents. Developed by Daily, it enables fully programmable AI voice agents and supports multimodal interactions, positioning itself as a flexible solution for developers looking to build conversational AI systems.
This guide explains how to integrate Opik with Pipecat for observability and tracing of real-time voice agents, enabling you to monitor, debug, and optimize your Pipecat agents in the Opik dashboard.
Comet provides a hosted version of the Opik platform, simply create an account and grab your API Key.
<Frame> </Frame>You can also run the Opik platform locally, see the installation guide for more information.
To use the Pipecat integration with Opik, you will need to have Pipecat and the required OpenTelemetry packages installed:
pip install pipecat-ai[daily,webrtc,silero,cartesia,deepgram,openai,tracing] opentelemetry-exporter-otlp-proto-http websockets
For the basic example, you'll need an OpenAI API key. You can set it as an environment variable:
export OPENAI_API_KEY="YOUR_OPENAI_API_KEY"
Or set it programmatically:
import os
import getpass
if "OPENAI_API_KEY" not in os.environ:
os.environ["OPENAI_API_KEY"] = getpass.getpass("Enter your OpenAI API key: ")
Enable tracing in your Pipecat application by setting up OpenTelemetry instrumentation and configuring your pipeline task. For complete details on Pipecat's OpenTelemetry implementation, see the official Pipecat OpenTelemetry documentation:
# Initialize OpenTelemetry with the http exporter
from opentelemetry.exporter.otlp.proto.http.trace_exporter import OTLPSpanExporter
from pipecat.utils.tracing.setup import setup_tracing
# Configured automatically from .env
exporter = OTLPSpanExporter()
setup_tracing(
service_name="pipecat-demo",
exporter=exporter,
)
# Enable tracing in your PipelineTask
task = PipelineTask(
pipeline,
params=PipelineParams(
allow_interruptions=True,
enable_metrics=True, # Required for some service metrics
),
enable_tracing=True, # Enables both turn and conversation tracing
conversation_id="customer-123", # Optional - will auto-generate if not provided
)
Pipecat organizes traces hierarchically following the natural structure of conversations, as documented in their OpenTelemetry guide:
Conversation (conversation_id)
├── turn
│ ├── stt (Speech-to-Text)
│ ├── llm (Language Model)
│ └── tts (Text-to-Speech)
└── turn
├── stt
├── llm
└── tts
This structure allows you to track the complete lifecycle of conversations and measure latency for individual turns and services.
Based on Pipecat's OpenTelemetry implementation, the traces include:
Once your Pipecat applications are traced with Opik, you can view the OpenTelemetry traces in the Opik UI. You will see:
If you would like to see us improve this integration, simply open a new feature request on Github.