Set up OpenTelemetry
To log Strands Agents using Galileo, the first step is to set up OpenTelemetry.1
Installation
Add the OpenTelemetry packages to your project:The
opentelemetry-api and opentelemetry-sdk packages provide the core OpenTelemetry functionality. The opentelemetry-exporter-otlp package enables sending traces to Galileo’s OTLP endpoint.2
Create environment variables for your Galileo settings
Set environment variables for your Galileo settings, for example in a
.env file:3
Get the authentication headers
The OTel headers is a dictionary containing your API key, project name, and Log stream name. The convention for OTel is to store this header as a single string of key=value pairs in the
OTEL_EXPORTER_OTLP_HEADERS environment variable.4
Get your endpoint
The OTel endpoint is different from Galileo’s regular API endpoint and is specifically designed to receive telemetry data in the OTLP format.If you are using app.galileo.ai, then the OTel endpoint is
https://api.galileo.ai/otel/traces.If you’re using a self-hosted Galileo deployment, replace the https://api.galileo.ai/otel/traces endpoint with your deployment URL. The format of this URL is based on your console URL, replacing console with api and appending /otel/traces.For example:- if your console URL is
https://console.galileo.example.com, the OTel endpoint would behttps://api.galileo.example.com/otel/traces - if your console URL is
https://console-galileo.apps.mycompany.com, the OTel endpoint would behttps://api-galileo.apps.mycompany.com/otel/traces
OTEL_EXPORTER_OTLP_ENDPOINT environment variable. For example:Log a Strands ADK agent using OpenTelemetry
Once OpenTelemetry is configured, you can use the OTel capabilities of Strands to log traces.1
Import the Strands Agent telemetry package
The Strands Agents SDK has telemetry support out of the box. Start by importing
StrandsTelemetry with the following code:2
Set up the exporter
You can now set up an OTel exporter for your Strands Agent:When you run your Strands Agent code, traces will be logged to Galileo.
Full example
Here is a full example based off the Strands Agent quickstart. You can find this project in the Galileo SDK examples repo. To run this example, create a.env file with the following values set, or set them as environment variables:
.env