에이전트 시각화
에이전트 시각화는 Graphviz 를 사용하여 에이전트와 그 관계의 구조화된 그래픽 표현을 생성할 수 있게 합니다. 이는 애플리케이션 내에서 에이전트, 도구, 핸드오프가 어떻게 상호작용하는지 이해하는 데 유용합니다.
설치
선택적 viz
종속성 그룹을 설치하세요:
그래프 생성
draw_graph
함수를 사용하여 에이전트 시각화를 생성할 수 있습니다. 이 함수는 다음과 같은 방향 그래프를 만듭니다:
- 에이전트는 노란색 상자로 표시됩니다
- MCP 서버는 회색 상자로 표시됩니다
- 도구는 녹색 타원으로 표시됩니다
- 핸드오프는 한 에이전트에서 다른 에이전트로 향하는 방향 에지입니다
사용 예시
import os
from agents import Agent, function_tool
from agents.mcp.server import MCPServerStdio
from agents.extensions.visualization import draw_graph
@function_tool
def get_weather(city: str) -> str:
return f"The weather in {city} is sunny."
spanish_agent = Agent(
name="Spanish agent",
instructions="You only speak Spanish.",
)
english_agent = Agent(
name="English agent",
instructions="You only speak English",
)
current_dir = os.path.dirname(os.path.abspath(__file__))
samples_dir = os.path.join(current_dir, "sample_files")
mcp_server = MCPServerStdio(
name="Filesystem Server, via npx",
params={
"command": "npx",
"args": ["-y", "@modelcontextprotocol/server-filesystem", samples_dir],
},
)
triage_agent = Agent(
name="Triage agent",
instructions="Handoff to the appropriate agent based on the language of the request.",
handoffs=[spanish_agent, english_agent],
tools=[get_weather],
mcp_servers=[mcp_server],
)
draw_graph(triage_agent)
이는 triage agent 의 구조와 하위 에이전트 및 도구와의 연결을 시각적으로 나타내는 그래프를 생성합니다.
시각화 이해
생성된 그래프에는 다음이 포함됩니다:
- 진입점을 나타내는 시작 노드 (
__start__
) - 노란색 채우기의 직사각형 으로 표시된 에이전트
- 녹색 채우기의 타원 으로 표시된 도구
- 회색 채우기의 직사각형 으로 표시된 MCP 서버
- 상호작용을 나타내는 방향 에지:
- 에이전트 간 핸드오프에는 실선 화살표
- 도구 호출에는 점선 화살표
- MCP 서버 호출에는 대시선 화살표
- 실행이 종료되는 위치를 나타내는 종료 노드 (
__end__
)
참고: MCP 서버는 최근 버전의
agents
패키지에서 렌더링됩니다 (v0.2.8 에서 확인됨). 시각화에 MCP 상자가 보이지 않는 경우 최신 릴리스로 업그레이드하세요.
그래프 커스터마이징
그래프 표시
기본적으로 draw_graph
는 그래프를 인라인으로 표시합니다. 그래프를 별도의 창에 표시하려면 다음을 작성하세요:
그래프 저장
기본적으로 draw_graph
는 그래프를 인라인으로 표시합니다. 파일로 저장하려면 파일 이름을 지정하세요:
이렇게 하면 작업 디렉터리에 agent_graph.png
가 생성됩니다.