LLM Observability
Project description
arize-phoenix-otel
Provides a lightweight wrapper around OpenTelemetry primitives with Phoenix-aware defaults.
These defaults are aware of the PHOENIX_COLLECTOR_ENDPOINT
, PHOENIX_PROJECT_NAME
, and
PHOENIX_CLIENT_HEADERS
environment variables.
Examples
The phoenix.otel
module provides a high-level register
function to configure OpenTelemetry
tracing by setting a global TracerProvider
. The register function can also configure headers
and whether or not to process spans one by one or by batch.
Quickstart
from phoenix.otel import register
tracer_provider = register()
This is all you need to get started using OTel with Phoenix! register
defaults to sending spans
to an endpoint at http://localhost
using gRPC.
Configuring the collector endpoint
There are two ways to configure the collector endpoint:
- Using environment variables
- Using the
endpoint
keyword argument
Using environment variables
If you're setting the PHOENIX_COLLECTOR_ENDPOINT
environment variable, register
will
automatically try to send spans to your Phoenix server using gRPC.
# export PHOENIX_COLLECTOR_ENDPOINT=https://your-phoenix.com:6006
from phoenix.otel import register
tracer_provider = register()
Specifying the endpoint
directly
When passing in the endpoint
argument, you must specify the fully qualified endpoint. For
example, in order to export spans via HTTP to localhost, use Pheonix's HTTP collector endpoint:
http://localhost:6006/v1/traces
. The gRPC endpoint is different: http://localhost:4317
.
from phoenix.otel import register
tracer_provider = register(endpoint="http://localhost:6006")
Additional configuration
register
can be configured with different keyword arguments:
project_name
: The Phoenix project name (orPHOENIX_PROJECT_NAME
env. var)headers
: Headers to send along with each span payload (orPHOENIX_CLIENT_HEADERS
env. var)batch
: Whether or not to process spans in batch
from phoenix.otel import register
tracer_provider = register(
project_name="otel-test", headers={"Authorization": "Bearer TOKEN"}, batch=True
)
A drop-in replacement for OTel primitives
For more granular tracing configuration, these wrappers can be used as drop-in replacements for OTel primitives:
from opentelemetry import trace as trace_api
from phoenix.otel import HTTPSpanExporter, TracerProvider, SimpleSpanProcessor
tracer_provider = TracerProvider()
span_exporter = HTTPSpanExporter(endpoint="http://localhost:6006/v1/traces")
span_processor = SimpleSpanProcessor(span_exporter=span_exporter)
tracer_provider.add_span_processor(span_processor)
trace_api.set_tracer_provider(tracer_provider)
Wrappers have Phoenix-aware defaults to greatly simplify the OTel configuration process. A special
endpoint
keyword argument can be passed to either a TracerProvider
, SimpleSpanProcessor
or
BatchSpanProcessor
in order to automatically infer which SpanExporter
to use to simplify setup.
Using environment variables
# export PHOENIX_COLLECTOR_ENDPOINT=http://localhost:6006
from opentelemetry import trace as trace_api
from phoenix.otel import TracerProvider
tracer_provider = TracerProvider()
trace_api.set_tracer_provider(tracer_provider)
Specifying the endpoint
directly
from opentelemetry import trace as trace_api
from phoenix.otel import TracerProvider
tracer_provider = TracerProvider(endpoint="http://localhost:4317")
trace_api.set_tracer_provider(tracer_provider)
Further examples
Users can gradually add OTel components as desired:
Configuring resources
# export PHOENIX_COLLECTOR_ENDPOINT=http://localhost:6006
from opentelemetry import trace as trace_api
from phoenix.otel import Resource, PROJECT_NAME, TracerProvider
tracer_provider = TracerProvider(resource=Resource({PROJECT_NAME: "my-project"}))
trace_api.set_tracer_provider(tracer_provider)
Using a BatchSpanProcessor
# export PHOENIX_COLLECTOR_ENDPOINT=http://localhost:6006
from opentelemetry import trace as trace_api
from phoenix.otel import TracerProvider, BatchSpanProcessor
tracer_provider = TracerProvider()
batch_processor = BatchSpanProcessor()
tracer_provider.add_span_processor(batch_processor)
Specifying a custom GRPC endpoint
from opentelemetry import trace as trace_api
from phoenix.otel import TracerProvider, BatchSpanProcessor, GRPCSpanExporter
tracer_provider = TracerProvider()
batch_processor = BatchSpanProcessor(
span_exporter=GRPCSpanExporter(endpoint="http://custom-endpoint.com")
)
tracer_provider.add_span_processor(batch_processor)
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
Built Distribution
File details
Details for the file arize_phoenix_otel-0.3.0.tar.gz
.
File metadata
- Download URL: arize_phoenix_otel-0.3.0.tar.gz
- Upload date:
- Size: 8.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 72ff8b107013bf9191249047d122f146ca4cbecb055914a119341aef916b3424 |
|
MD5 | 6d41a8ed82fa2558591632285f5f426a |
|
BLAKE2b-256 | 274442aea97b00cd8b7a62132592ad3dd7ba92b7d4d7984feccdbfa8363b0046 |
File details
Details for the file arize_phoenix_otel-0.3.0-py3-none-any.whl
.
File metadata
- Download URL: arize_phoenix_otel-0.3.0-py3-none-any.whl
- Upload date:
- Size: 9.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 66d53be0ceb6488199ac6836b94fb93cb94164c937baf92de705b6f82ce5b97c |
|
MD5 | e1e3109dd7ff7a114d566509ec6f9b24 |
|
BLAKE2b-256 | 770d70239a68b258e5f887d70a6756bd120a70515a96f49f95724e46969b6bb2 |