TypeScript Strands Agent para MCP
O gerador connection pode conectar seu TypeScript Strands Agent a um servidor MCP (seja TypeScript ou Python).
O gerador configura toda a infraestrutura necessária para que seu agente possa descobrir e invocar as ferramentas do servidor MCP, tanto quando implantado na AWS (via Bedrock AgentCore) quanto quando executado localmente.
Pré-requisitos
Seção intitulada “Pré-requisitos”Antes de usar este gerador, certifique-se de ter:
- Um projeto TypeScript com um componente Strands Agent
- Um projeto com um componente de servidor MCP (seja
ts#mcp-serveroupy#mcp-server) - Ambos os componentes criados com
computeType: BedrockAgentCoreRuntime
Execute o Gerador
Seção intitulada “Execute o Gerador”- Instale o Nx Console VSCode Plugin se ainda não o fez
- Abra o console Nx no VSCode
- Clique em
Generate (UI)na seção "Common Nx Commands" - Procure por
@aws/nx-plugin - connection - Preencha os parâmetros obrigatórios
- Clique em
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:connectionVocê também pode realizar uma execução simulada para ver quais arquivos seriam alterados
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-runSelecione seu projeto de agente como origem e seu projeto de servidor MCP como destino. Se seus projetos contiverem múltiplos componentes, especifique as opções sourceComponent e targetComponent para desambiguar.
| Parâmetro | Tipo | Padrão | Descrição |
|---|---|---|---|
| sourceProject Obrigatório | string | - | The source project |
| targetProject Obrigatório | string | - | The target project to connect to |
| sourceComponent | string | - | The source component to connect from (component name, path relative to source project root, or generator id). Use '.' to explicitly select the project as the source. |
| targetComponent | string | - | The target component to connect to (component name, path relative to target project root, or generator id). Use '.' to explicitly select the project as the target. |
Saída do Gerador
Seção intitulada “Saída do Gerador”O gerador cria um pacote compartilhado agent-connection e modifica o código do seu agente:
Directorypackages/common/agent-connection
Directorysrc
Directoryapp
- <mcp-server-name>-client.ts Cliente de alto nível para o servidor MCP conectado
Directorycore
- agentcore-mcp-client.ts Cliente MCP AgentCore de baixo nível com autenticação SigV4/JWT
- index.ts Exporta todos os clientes
- project.json
- tsconfig.json
Além disso, ele:
- Transforma o
agent.tsdo seu agente para importar e usar as ferramentas do servidor MCP - Atualiza o alvo
serve-localdo agente para depender do alvo serve do servidor MCP - Instala as dependências necessárias
Usando o Servidor MCP Conectado
Seção intitulada “Usando o Servidor MCP Conectado”O gerador transforma o agent.ts do seu agente para usar as ferramentas do servidor MCP:
import { Agent, tool } from '@strands-agents/sdk';import { MyMcpServerClient } from ':my-scope/agent-connection';
export const getAgent = async (sessionId: string) => { const myMcpServerClient = await MyMcpServerClient.create(sessionId); return new Agent({ systemPrompt: '...', tools: [myMcpServerClient], });};O parâmetro sessionId é propagado do chamador, garantindo consistência para Bedrock AgentCore Observability.
Infraestrutura
Seção intitulada “Infraestrutura”Após executar o gerador de conexão, você precisa conceder ao agente permissão para invocar o servidor 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.agentCoreRuntime.grantInvoke(myAgent.agentCoreRuntime);O ARN do runtime AgentCore do servidor MCP é automaticamente registrado no namespace connection da Configuração de Runtime pelo construto CDK gerado, para que o agente possa descobri-lo em tempo de execução.
Após executar o gerador de conexão, você precisa conceder ao agente permissão para invocar o servidor MCP na sua configuração 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}O ARN do runtime AgentCore do servidor MCP é automaticamente registrado no namespace connection da Configuração de Runtime pelo módulo Terraform gerado, para que o agente possa descobri-lo em tempo de execução.
Desenvolvimento Local
Seção intitulada “Desenvolvimento Local”O gerador configura o alvo serve-local do agente para:
- Iniciar o(s) servidor(es) MCP conectado(s) automaticamente
- Definir
SERVE_LOCAL=truepara que o cliente gerado use transporte HTTP direto em vez de AgentCore
Execute o agente localmente com:
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>Isso iniciará tanto o agente quanto todos os servidores MCP conectados, com o agente se conectando aos servidores MCP diretamente via HTTP em suas portas locais atribuídas.