Commit f153fb0
fix: propagate OpenTelemetry trace context to subagent calls (#704)
## Problem
When using a subagent as a tool, the subagent's OpenTelemetry spans have
a different traceId than the main agent's spans, breaking distributed
trace continuity.
## Root Cause
- `AgentBase.createEventStream()` synchronously calls
`callSupplier.get()` outside of Reactor subscription context
- `SubAgentTool` methods don't propagate Reactor Context containing
trace information to downstream agent invocations
## Solution
Use `Mono.defer()` and `.contextWrite()` to propagate Reactor Context
containing trace information to agent calls.
## Changes
- **AgentBase.createEventStream()**: Use `Mono.defer()` to delay
execution until subscription when trace context is available
- **SubAgentTool.executeWithStreaming()**: Add `.contextWrite(context ->
context.putAll(ctxView))` to propagate trace context
- **SubAgentTool.executeWithoutStreaming()**: Add `.contextWrite(context
-> context.putAll(ctxView))` to propagate trace context
## Impact
This ensures main agent and subagent share the same traceId in
distributed tracing systems like Langfuse and Jaeger.
## Testing
- Verified with LangfuseExample that main agent and subagent now share
the same traceId
- All spans show proper parent-child relationships in the trace
visualization
---
**Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>**
---------
Co-authored-by: Claude Sonnet 4.5 <noreply@anthropic.com>1 parent 467df7b commit f153fb0
File tree
2 files changed
+77
-59
lines changed- agentscope-core/src/main/java/io/agentscope/core
- agent
- tool/subagent
2 files changed
+77
-59
lines changedLines changed: 40 additions & 34 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
664 | 664 | | |
665 | 665 | | |
666 | 666 | | |
667 | | - | |
668 | | - | |
669 | | - | |
670 | | - | |
671 | | - | |
672 | | - | |
673 | | - | |
674 | | - | |
675 | | - | |
676 | | - | |
677 | | - | |
678 | | - | |
679 | | - | |
680 | | - | |
681 | | - | |
682 | | - | |
683 | | - | |
684 | | - | |
685 | | - | |
686 | | - | |
687 | | - | |
688 | | - | |
689 | | - | |
690 | | - | |
691 | | - | |
692 | | - | |
693 | | - | |
694 | | - | |
695 | | - | |
696 | | - | |
697 | | - | |
698 | | - | |
699 | | - | |
700 | | - | |
| 667 | + | |
| 668 | + | |
| 669 | + | |
| 670 | + | |
| 671 | + | |
| 672 | + | |
| 673 | + | |
| 674 | + | |
| 675 | + | |
| 676 | + | |
| 677 | + | |
| 678 | + | |
| 679 | + | |
| 680 | + | |
| 681 | + | |
| 682 | + | |
| 683 | + | |
| 684 | + | |
| 685 | + | |
| 686 | + | |
| 687 | + | |
| 688 | + | |
| 689 | + | |
| 690 | + | |
| 691 | + | |
| 692 | + | |
| 693 | + | |
| 694 | + | |
| 695 | + | |
| 696 | + | |
| 697 | + | |
| 698 | + | |
| 699 | + | |
| 700 | + | |
| 701 | + | |
| 702 | + | |
| 703 | + | |
| 704 | + | |
| 705 | + | |
| 706 | + | |
701 | 707 | | |
702 | 708 | | |
703 | 709 | | |
| |||
Lines changed: 37 additions & 25 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
122 | 122 | | |
123 | 123 | | |
124 | 124 | | |
125 | | - | |
126 | | - | |
| 125 | + | |
| 126 | + | |
127 | 127 | | |
128 | 128 | | |
129 | 129 | | |
| |||
246 | 246 | | |
247 | 247 | | |
248 | 248 | | |
249 | | - | |
250 | | - | |
251 | | - | |
252 | | - | |
253 | | - | |
254 | | - | |
255 | | - | |
256 | | - | |
257 | | - | |
258 | | - | |
259 | | - | |
260 | | - | |
261 | | - | |
262 | | - | |
263 | | - | |
| 249 | + | |
| 250 | + | |
| 251 | + | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
| 262 | + | |
| 263 | + | |
| 264 | + | |
| 265 | + | |
| 266 | + | |
| 267 | + | |
| 268 | + | |
| 269 | + | |
| 270 | + | |
264 | 271 | | |
265 | 272 | | |
266 | 273 | | |
| |||
276 | 283 | | |
277 | 284 | | |
278 | 285 | | |
279 | | - | |
280 | | - | |
281 | | - | |
282 | | - | |
283 | | - | |
284 | | - | |
285 | | - | |
286 | | - | |
| 286 | + | |
| 287 | + | |
| 288 | + | |
| 289 | + | |
| 290 | + | |
| 291 | + | |
| 292 | + | |
| 293 | + | |
| 294 | + | |
| 295 | + | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
287 | 299 | | |
288 | 300 | | |
289 | 301 | | |
| |||
0 commit comments