Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Inconsitency in APM trace spans relating LangChain integration #11477

Open
Peilun-Li opened this issue Nov 21, 2024 · 0 comments
Open

Inconsitency in APM trace spans relating LangChain integration #11477

Peilun-Li opened this issue Nov 21, 2024 · 0 comments
Assignees
Labels
MLObs ML Observability (LLMObs)

Comments

@Peilun-Li
Copy link

Peilun-Li commented Nov 21, 2024

Environment

  • dd-trace-py: 2.16.4
  • langchain-core: 0.2.34
  • langchain-community: 0.2.1
  • langchain-openai: 0.1.8

Reproduce

A standard langchain AgentExecutor with a retriever tool: https://python.langchain.com/docs/how_to/agent_executor/#retriever and ainvoke the agent with a question to trigger the retriever tool.

Expectation

APM trace span for the request would show three sections:

  1. Initial call to LLM (LLM returns desire to usage the retriever tool)
  2. Call retriever/vector store
  3. Second call to LLM (LLM generates answer with retrieved context)

Actual behavior

Inconsistent behavior of APM trace span among four test calls (all same output and all triggered tool usage)

First call only shows 1. and 2. above (2. is inferred through request)
Image

Second call only shows 1.
Image

Third call only shows 1. and 2., with 1. incomplete (only 2 levels compared to 4 levels in the first call)
Image

Fourth call only shows 1. and 3., with 3. incomplete (expect the same 4 levels for OpenAI calls but only get 2 levels)
Image

To summarize, it looks like while we do support inject spans for all the expected three sections, they are quite unstable and inconsistent across requests. Could it be due to some setup from our application side, or a ddtrace library issue, or some others? Appreciate any help/insight!

@mabdinur mabdinur added the MLObs ML Observability (LLMObs) label Jan 2, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
MLObs ML Observability (LLMObs)
Projects
None yet
Development

No branches or pull requests

3 participants