AI agents may invoke tools, call other agents, or prompt a Generative AI (GenAI) model with multi-step user input. The distributed and non-deterministic nature of agentic workflows makes monitoring and debugging difficult. Instrument your AI agents with OpenTelemetry (OTel) GenAI semantic conventions to get full visibility into agent sessions and explore your agents in the Agent Timeline.Documentation Index
Fetch the complete documentation index at: https://docs.honeycomb.io/llms.txt
Use this file to discover all available pages before exploring further.
- Refer to Fast AI Feedback Loops with Honeycomb and OpenTelemetry for an example of agent instrumentation using Pydantic.
- Visit the example storechat application repo for further agent instrumentation examples.
Enriching your traces with GenAI context
Add the following OTel GenAI attributes to your agent spans to give Honeycomb the context it needs to group spans into conversations, identify agents, and surface meaningful data in the Agent Timeline.Unique identifier for the conversation or session. Used to group all traces and spans belonging to the same agent conversation.
Name of the agent emitting the span.In multi-agent workflows each agent should have a unique name.
Type of agentic operation occurring:
chatcreate_agentembeddingsexecute_toolgenerate_contentinvoke_agentinvoke_workflowretrievaltext_completion
Number of tokens used in the GenAI input prompt.
Number of tokens used in the GenAI response.
Name of the model requested.
Name of the model that generated the response. This can differ from the requested model.
Why the model stopped generating tokens.Examples:
["stop"], ["tool_calls"], ["stop", "length"]Name of the tool called by the agent.
Unique identifier for the tool call.
Parameters passed to the tool call.
Result returned by the tool call (if any).To learn how to handle failed tool calls, refer to the Recording errors and exceptions section.
Span events for input prompts, completions, and evaluations
Full prompts, chat history, and completion responses may be too large or contain personally identifiable information (PII) or other sensitive data. Store them in span events where your OTel Collector can filter them before they reach Honeycomb.Chat history or input prompts provided to the model.
GenAI prompts or chats may contain PII or other sensitive data.
Messages returned by the model. Each message represents a specific model response.
GenAI responses may contain PII or other sensitive data.
Attach
gen_ai.evaluation.result events to the GenAI operation span to review evaluations in the GenAI tab.Keeping agent names unique
The Agent Timeline groups spans bygen_ai.agent.name, so duplicate or missing names make it impossible to distinguish between agents during an investigation.
Each agent should have its own unique gen_ai.agent.name.
Sub-agents should use their own distinct name, instead of inheriting the parent agent’s name.
If
gen_ai.agent.name is omitted on a span, it will show up as "Unknown" on the Agent Timeline.Instrumenting agent-to-agent calls
In multi-agent workflows, correctly attributing spans to the right agent is what makes the Agent Timeline useful. The calling agent should emit theinvoke_agent span, not the agent being called.
The called agent then emits its own spans (chat, execute_tool, and so on) under its own unique gen_ai.agent.name, keeping each agent’s work distinct and traceable in the timeline.
To learn more about agent invocation spans, visit the OTel documentation:
Handling errors and exceptions
Agentic workflows can fail in subtle ways: a tool call that silently drops its result, or an error that surfaces in a child span but never reaches the parent. Recording errors consistently gives you the full picture when something goes wrong. Record errors or exceptions following the OTel specification and include as many attributes as apply:error.type/exception.typeerror.message/exception.messageerror.stacktrace/exception.stacktrace
Naming generative AI operation spans
Generative AI operation spans should follow these naming conventions. Naming your spans this way ensures the Agent Timeline can understand the operation type and display it meaningfully.| Operation | gen_ai.operation.name | Span Name Pattern |
|---|---|---|
| Chat | chat | chat {model} |
| Create GenAI agent | create_agent | create_agent {agent_name} |
| Tool execution | execute_tool | execute_tool {tool_name} |
| Agent invocation | invoke_agent | invoke_agent {agent_name} |
| Embeddings | embeddings | embeddings {model} |
| RAG retrieval | retrieval | retrieval {data_source} |
| Multimodal content generation | generate_content | generate_content {model} |
| Text completions | text_completion | text_completion {model} |
Remapping existing telemetry
In some cases, your existing telemetry may not conform to OpenTelemetry semantic conventions. Thetransform processor lets you remap those attributes before they reach Honeycomb.
For example, Claude Code can emit telemetry using the OpenTelemetry protocol, but does not yet use the OpenTelemetry semantic conventions.
The following configuration remaps Claude Code’s emitted traces to match the OpenTelemetry semantic conventions, making them visible in the Agent Timeline.