Ir al contenido

Agente TypeScript Strands a MCP

El generador connection puede conectar tu TypeScript Strands Agent a un servidor MCP (ya sea TypeScript o Python).

El generador configura todo el cableado necesario para que tu agente pueda descubrir e invocar las herramientas del servidor MCP, tanto cuando está desplegado en AWS (a través de Bedrock AgentCore) como cuando se ejecuta localmente.

Antes de usar este generador, asegúrate de tener:

  1. Un proyecto TypeScript con un componente Strands Agent
  2. Un proyecto con un componente de servidor MCP (ya sea ts#mcp-server o py#mcp-server)
  3. Ambos componentes creados con computeType: BedrockAgentCoreRuntime
  1. Instale el Nx Console VSCode Plugin si aún no lo ha hecho
  2. Abra la consola Nx en VSCode
  3. Haga clic en Generate (UI) en la sección "Common Nx Commands"
  4. Busque @aws/nx-plugin - connection
  5. Complete los parámetros requeridos
    • Haga clic en Generate

    Selecciona tu proyecto de agente como origen y tu proyecto de servidor MCP como destino. Si tus proyectos contienen múltiples componentes, especifica las opciones sourceComponent y targetComponent para desambiguar.

    Parámetro Tipo Predeterminado Descripción
    sourceProject Requerido string - The source project
    targetProject Requerido 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.

    El generador crea un paquete compartido agent-connection y modifica el código de tu agente:

    • Directoriopackages/common/agent-connection
      • Directoriosrc
        • Directorioapp
          • <mcp-server-name>-client.ts Cliente de alto nivel para el servidor MCP conectado
        • Directoriocore
          • agentcore-mcp-client.ts Cliente MCP AgentCore de bajo nivel con autenticación SigV4/JWT
        • index.ts Exporta todos los clientes
      • project.json
      • tsconfig.json

    Además:

    • Transforma el agent.ts de tu agente para importar y usar las herramientas del servidor MCP
    • Actualiza el objetivo serve-local del agente para que dependa del objetivo serve del servidor MCP
    • Instala las dependencias requeridas

    El generador transforma el agent.ts de tu agente para usar las herramientas del servidor MCP:

    packages/example/src/my-agent/agent.ts
    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],
    });
    };

    El parámetro sessionId se transmite desde el llamador, asegurando consistencia para Bedrock AgentCore Observability.

    Después de ejecutar el generador de conexión, necesitas otorgar al agente permiso para invocar el servidor MCP:

    packages/infra/src/stacks/application-stack.ts
    const mcpServer = new MyMcpServer(this, 'MyMcpServer');
    const myAgent = new MyAgent(this, 'MyAgent');
    // Grant the agent access to bedrock models
    myAgent.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 server
    mcpServer.agentCoreRuntime.grantInvoke(myAgent.agentCoreRuntime);

    El ARN del runtime AgentCore del servidor MCP se registra automáticamente en el namespace connection de Runtime Configuration por el constructo CDK generado, para que el agente pueda descubrirlo en tiempo de ejecución.

    El generador configura el objetivo serve-local del agente para:

    1. Iniciar automáticamente el/los servidor(es) MCP conectado(s)
    2. Establecer SERVE_LOCAL=true para que el cliente generado use transporte HTTP directo en lugar de AgentCore

    Ejecuta el agente localmente con:

    Terminal window
    pnpm nx <agent-name>-serve-local <project-name>

    Esto iniciará tanto el agente como todos los servidores MCP conectados, con el agente conectándose a los servidores MCP directamente a través de HTTP en sus puertos locales asignados.