Python Strands Agent a MCP
Il generatore connection può connettere il tuo Python Strands Agent a un server MCP (sia TypeScript che Python).
Il generatore configura tutti i collegamenti necessari in modo che il tuo agente possa scoprire e invocare gli strumenti del server MCP, sia quando viene distribuito su AWS (tramite Bedrock AgentCore) che quando viene eseguito localmente.
Prerequisiti
Sezione intitolata “Prerequisiti”Prima di utilizzare questo generatore, assicurati di avere:
- Un progetto Python con un componente Strands Agent
- Un progetto con un componente server MCP (sia
ts#mcp-serverchepy#mcp-server) - Entrambi i componenti creati con
computeType: BedrockAgentCoreRuntime
Utilizzo
Sezione intitolata “Utilizzo”Eseguire il Generatore
Sezione intitolata “Eseguire il Generatore”- Installa il Nx Console VSCode Plugin se non l'hai già fatto
- Apri la console Nx in VSCode
- Clicca su
Generate (UI)nella sezione "Common Nx Commands" - Cerca
@aws/nx-plugin - connection - Compila i parametri richiesti
- Clicca su
Generate
pnpm nx g @aws/nx-plugin:connectionyarn nx g @aws/nx-plugin:connectionnpx nx g @aws/nx-plugin:connectionbunx nx g @aws/nx-plugin:connectionPuoi anche eseguire una prova per vedere quali file verrebbero modificati
pnpm nx g @aws/nx-plugin:connection --dry-runyarn nx g @aws/nx-plugin:connection --dry-runnpx nx g @aws/nx-plugin:connection --dry-runbunx nx g @aws/nx-plugin:connection --dry-runSeleziona il tuo progetto agente come sorgente e il tuo progetto server MCP come destinazione. Se i tuoi progetti contengono più componenti, specifica le opzioni sourceComponent e targetComponent per disambiguare.
Opzioni
Sezione intitolata “Opzioni”| Parametro | Tipo | Predefinito | Descrizione |
|---|---|---|---|
| sourceProject Obbligatorio | string | - | Il progetto sorgente |
| targetProject Obbligatorio | string | - | Il progetto di destinazione a cui connettersi |
| sourceComponent | string | - | Il componente sorgente da cui connettersi (nome del componente, percorso relativo alla radice del progetto sorgente, o id del generatore). Usare '.' per selezionare esplicitamente il progetto come sorgente. |
| targetComponent | string | - | Il componente di destinazione a cui connettersi (nome del componente, percorso relativo alla radice del progetto di destinazione, o id del generatore). Usare '.' per selezionare esplicitamente il progetto come destinazione. |
Output del Generatore
Sezione intitolata “Output del Generatore”Il generatore crea un progetto Python condiviso agent_connection in packages/common/agent_connection/ (se non esiste già). I moduli client per-connessione vengono generati in questo progetto condiviso:
Directorypackages/common/agent_connection
Directory<scope>_agent_connection
- __init__.py Ri-esporta i client per-connessione
Directorycore
- agentcore_mcp_client.py Client MCP AgentCore di base
Directoryapp
- <mcp_server_name>_client.py Client per-connessione per ogni server MCP
Inoltre, il generatore:
- Trasforma il file
agent.pydel tuo agente per importare e utilizzare gli strumenti del server MCP tramite un client basato su classi - Aggiunge il progetto
agent_connectioncome dipendenza del workspace del tuo progetto agente - Aggiorna il target
serve-localdell’agente per dipendere dal target serve del server MCP
Utilizzo del Server MCP Connesso
Sezione intitolata “Utilizzo del Server MCP Connesso”Il generatore trasforma il file agent.py del tuo agente per utilizzare gli strumenti del server MCP:
from contextlib import contextmanagerfrom strands import Agent
from my_scope_agent_connection import MyMcpServerClient
@contextmanagerdef get_agent(session_id: str): my_mcp_server = MyMcpServerClient.create(session_id=session_id) with ( my_mcp_server, ): yield Agent( system_prompt="...", tools=[*my_mcp_server.list_tools_sync()], )Il parametro session_id viene passato dal chiamante, garantendo la coerenza per Bedrock AgentCore Observability.
Infrastruttura
Sezione intitolata “Infrastruttura”Dopo aver eseguito il generatore di connessione, devi concedere all’agente il permesso di invocare il server MCP:
const mcpServer = new MyMcpServer(this, 'MyMcpServer');const myAgent = new MyAgent(this, 'MyAgent');
// Grant the agent access to bedrock modelsmyAgent.agentCoreRuntime.addToRolePolicy( new PolicyStatement({ actions: ['bedrock:InvokeModel', 'bedrock:InvokeModelWithResponseStream'], resources: ['arn:aws:bedrock:*:*:foundation-model/*', 'arn:aws:bedrock:*:*:inference-profile/*'], }),);
// Grant the agent permissions to invoke the MCP servermcpServer.grantInvokeAccess(myAgent.agentCoreRuntime);L’ARN del runtime AgentCore del server MCP viene registrato automaticamente nel namespace connection della Runtime Configuration dal costrutto CDK generato, in modo che l’agente possa scoprirlo a runtime.
Dopo aver eseguito il generatore di connessione, devi concedere all’agente il permesso di invocare il server MCP nella tua configurazione Terraform:
module "inventory_mcp_server" { source = "../../common/terraform/src/app/mcp-servers/inventory-mcp"}
module "story_agent" { source = "../../common/terraform/src/app/agents/story-agent"}
# Grant the agent permissions to invoke the MCP serverresource "aws_iam_policy" "agent_invoke_mcp" { name = "AgentInvokeMcpPolicy" policy = jsonencode({ Version = "2012-10-17" Statement = [{ Effect = "Allow" Action = "bedrock-agentcore:InvokeAgent" Resource = module.inventory_mcp_server.agent_core_runtime_arn }] })}
resource "aws_iam_role_policy_attachment" "agent_invoke_mcp" { role = module.story_agent.agent_core_runtime_role_arn policy_arn = aws_iam_policy.agent_invoke_mcp.arn}L’ARN del runtime AgentCore del server MCP viene registrato automaticamente nel namespace connection della Runtime Configuration dal modulo Terraform generato, in modo che l’agente possa scoprirlo a runtime.
Sviluppo Locale
Sezione intitolata “Sviluppo Locale”Il generatore configura il target serve-local dell’agente per:
- Avviare automaticamente i server MCP connessi
- Impostare
SERVE_LOCAL=truein modo che il client generato utilizzi il trasporto HTTP diretto invece di AgentCore
Esegui l’agente localmente con:
pnpm nx <agent-name>-serve-local <project-name>yarn nx <agent-name>-serve-local <project-name>npx nx <agent-name>-serve-local <project-name>bunx nx <agent-name>-serve-local <project-name>Questo avvierà sia l’agente che tutti i server MCP connessi, con l’agente che si connette ai server MCP direttamente tramite HTTP sulle loro porte locali assegnate.