Bỏ qua để đến nội dung

Python Strands Agent tới MCP

Trình tạo connection có thể kết nối Python Strands Agent của bạn với một MCP server (có thể là TypeScript hoặc Python).

Trình tạo thiết lập tất cả các kết nối cần thiết để agent của bạn có thể khám phá và gọi các công cụ của MCP server, cả khi triển khai lên AWS (thông qua Bedrock AgentCore) và khi chạy cục bộ.

Trước khi sử dụng trình tạo này, hãy đảm bảo bạn có:

  1. Một dự án Python với component Strands Agent
  2. Một dự án với component MCP server (có thể là ts#mcp-server hoặc py#mcp-server)
  3. Cả hai component được tạo với computeType: BedrockAgentCoreRuntime
  1. Cài đặt Nx Console VSCode Plugin nếu bạn chưa cài đặt
  2. Mở Nx Console trong VSCode
  3. Nhấp Generate (UI) trong phần "Common Nx Commands"
  4. Tìm kiếm @aws/nx-plugin - connection
  5. Điền các tham số bắt buộc
    • Nhấp Generate

    Chọn dự án agent của bạn làm nguồn và dự án MCP server của bạn làm đích. Nếu dự án của bạn chứa nhiều component, hãy chỉ định các tùy chọn sourceComponenttargetComponent để phân biệt.

    Tham số Kiểu Mặc định Mô tả
    sourceProject Bắt buộc string - Dự án nguồn
    targetProject Bắt buộc string - Dự án đích để kết nối tới
    sourceComponent string - Component nguồn để kết nối từ đó (tên component, đường dẫn tương đối so với thư mục gốc của dự án nguồn, hoặc generator id). Sử dụng '.' để chọn rõ ràng dự án làm nguồn.
    targetComponent string - Component đích để kết nối tới (tên component, đường dẫn tương đối so với thư mục gốc của dự án đích, hoặc generator id). Sử dụng '.' để chọn rõ ràng dự án làm đích.

    Trình tạo tạo một dự án Python agent_connection được chia sẻ tại packages/common/agent_connection/ (nếu chưa tồn tại). Các module client theo từng kết nối được tạo vào dự án được chia sẻ này:

    • Thư mụcpackages/common/agent_connection
      • Thư mục<scope>_agent_connection
        • __init__.py Xuất lại các client theo từng kết nối
        • Thư mụccore
          • agentcore_mcp_client.py Client MCP AgentCore cốt lõi
        • Thư mụcapp
          • <mcp_server_name>_client.py Client theo từng kết nối cho mỗi MCP server

    Ngoài ra, trình tạo còn:

    • Chuyển đổi agent.py của agent để import và sử dụng các công cụ của MCP server thông qua một client dựa trên class
    • Thêm dự án agent_connection làm dependency workspace của dự án agent
    • Cập nhật target serve-local của agent để phụ thuộc vào target serve của MCP server

    Trình tạo chuyển đổi agent.py của agent để sử dụng các công cụ của MCP server:

    packages/my-project/my_module/agent/agent.py
    from contextlib import contextmanager
    from strands import Agent
    from my_scope_agent_connection import MyMcpServerClient
    @contextmanager
    def 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()],
    )

    Tham số session_id được truyền từ người gọi, đảm bảo tính nhất quán cho Bedrock AgentCore Observability.

    Sau khi chạy trình tạo kết nối, bạn cần cấp quyền cho agent để gọi MCP server:

    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.grantInvokeAccess(myAgent.agentCoreRuntime);

    ARN runtime AgentCore của MCP server được tự động đăng ký trong namespace connection của Runtime Configuration bởi CDK construct được tạo, để agent có thể khám phá nó tại runtime.

    Trình tạo cấu hình target serve-local của agent để:

    1. Tự động khởi động (các) MCP server đã kết nối
    2. Đặt SERVE_LOCAL=true để client được tạo sử dụng truyền tải HTTP trực tiếp thay vì AgentCore

    Chạy agent cục bộ với:

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

    Điều này sẽ khởi động cả agent và tất cả các MCP server đã kết nối, với agent kết nối trực tiếp đến các MCP server thông qua HTTP trên các cổng cục bộ được chỉ định của chúng.