Pular para o conteúdo

Servidor Python MCP

Gere um servidor Python do Model Context Protocol (MCP) para fornecer contexto a Large Language Models (LLMs), e opcionalmente implante-o no Amazon Bedrock AgentCore.

O Model Context Protocol (MCP) é um padrão aberto que permite assistentes de IA interagirem com ferramentas e recursos externos. Ele fornece uma maneira consistente para LLMs:

  • Executar ferramentas (funções) que realizam ações ou recuperam informações
  • Acessar recursos que fornecem contexto ou dados

Você pode gerar um servidor MCP Python de duas formas:

  1. Instale o Nx Console VSCode Plugin se ainda não o fez
  2. Abra o console Nx no VSCode
  3. Clique em Generate (UI) na seção "Common Nx Commands"
  4. Procure por @aws/nx-plugin - py#mcp-server
  5. Preencha os parâmetros obrigatórios
    • Clique em Generate
    Parâmetro Tipo Padrão Descrição
    project Obrigatório string - The project to add an MCP server to
    computeType string BedrockAgentCoreRuntime The type of compute to host your MCP server. Select None for no hosting.
    name string - The name of your MCP server (default: mcp-server)
    iacProvider string CDK The preferred IaC provider

    O gerador adicionará os seguintes arquivos ao seu projeto Python existente:

    • Directoryyour-project/
      • Directoryyour_module/
        • Directorymcp_server/ (ou nome personalizado se especificado)
          • __init__.py Inicialização do pacote Python
          • server.py Definição principal do servidor com ferramentas e recursos de exemplo
          • stdio.py Ponto de entrada para transporte STDIO, útil para servidores MCP locais simples
          • http.py Ponto de entrada para transporte HTTP Streamable, útil para hospedar seu servidor MCP
          • Dockerfile Ponto de entrada para hospedar seu servidor MCP (excluído quando computeType é None)
      • pyproject.toml Atualizado com dependências MCP
      • project.json Atualizado com alvos de serviço do servidor MCP

    Como este gerador fornece infraestrutura como código com base no iacProvider escolhido, ele criará um projeto em packages/common que inclui os constructs CDK ou módulos Terraform relevantes.

    O projeto comum de infraestrutura como código está estruturado da seguinte forma:

    • Directorypackages/common/constructs
      • Directorysrc
        • Directoryapp/ Constructs para infraestrutura específica de um projeto/gerador
        • Directorycore/ Constructs genéricos reutilizados pelos constructs em app
        • index.ts Ponto de entrada exportando os constructs de app
      • project.json Metas de build e configuração do projeto

    Para implantar seu MCP Server, os seguintes arquivos são gerados:

    • Directorypackages/common/constructs/src
      • Directoryapp
        • Directorymcp-servers
          • Directory<project-name>
            • <project-name>.ts Construto CDK para implantar seu MCP Server
            • Dockerfile Arquivo Docker passthrough usado pelo construto CDK
      • Directorycore
        • Directoryagent-core
          • runtime.ts Construto CDK genérico para implantação no Bedrock AgentCore Runtime

    Ferramentas são funções que o assistente de IA pode chamar para executar ações. O servidor MCP Python usa a biblioteca MCP Python SDK (FastMCP), que fornece uma abordagem baseada em decoradores para definir ferramentas.

    Você pode adicionar novas ferramentas no arquivo server.py:

    @mcp.tool(description="Descrição da sua ferramenta")
    def your_tool_name(param1: str, param2: int) -> str:
    """Implementação da ferramenta com type hints"""
    # Sua lógica da ferramenta aqui
    return f"Resultado: {param1} com {param2}"

    A biblioteca FastMCP trata automaticamente:

    • Validação de tipos baseada nas type hints da função
    • Geração de schema JSON para o protocolo MCP
    • Tratamento de erros e formatação de respostas

    Recursos fornecem contexto ao assistente de IA. Você pode adicioná-los usando o decorador @mcp.resource:

    @mcp.resource("example://static-resource", description="Exemplo de recurso estático")
    def static_resource() -> str:
    """Retorna conteúdo estático"""
    return "Este é um conteúdo estático que fornece contexto para a IA"
    @mcp.resource("dynamic://resource/{item_id}", description="Exemplo de recurso dinâmico")
    def dynamic_resource(item_id: str) -> str:
    """Retorna conteúdo dinâmico baseado em parâmetros"""
    # Busca dados baseado no item_id
    data = fetch_data_for_item(item_id)
    return f"Conteúdo dinâmico para {item_id}: {data}"

    A maioria dos assistentes de IA que suportam MCP usa uma abordagem de configuração semelhante. Você precisará criar ou atualizar um arquivo de configuração com os detalhes do seu servidor MCP:

    {
    "mcpServers": {
    "your-mcp-server": {
    "command": "uv",
    "args": [
    "run",
    "python",
    "-m",
    "my_module.mcp_server.stdio"
    ],
    "env": {
    "VIRTUAL_ENV": "/path/to/your/project/.venv"
    }
    }
    }
    }

    Consulte a documentação a seguir para configurar o MCP com assistentes de IA específicos:

    O gerador configura um alvo chamado <your-server-name>-inspect que inicia o MCP Inspector com a configuração para conectar ao seu servidor MCP usando transporte STDIO.

    Terminal window
    pnpm nx run your-project:your-server-name-inspect

    Isso iniciará o inspector em http://localhost:6274. Comece clicando no botão “Connect”.

    A maneira mais fácil de testar e usar um servidor MCP é através do inspector ou configurando com um assistente de IA (como acima).

    Você também pode executar seu servidor com transporte STDIO diretamente usando o alvo <your-server-name>-serve-stdio.

    Terminal window
    pnpm nx run your-project:your-server-name-serve-stdio

    Este comando usa uv run para executar seu servidor MCP com transporte STDIO.

    Se preferir executar seu servidor MCP localmente usando transporte HTTP Streamable, use o alvo <your-server-name>-serve-http.

    Terminal window
    pnpm nx run your-project:your-server-name-serve-http

    Este comando usa uv run para executar seu servidor MCP com transporte HTTP, normalmente na porta 8000.

    Implantando Seu Servidor MCP no Bedrock AgentCore Runtime

    Seção intitulada “Implantando Seu Servidor MCP no Bedrock AgentCore Runtime”

    Se você selecionou BedrockAgentCoreRuntime para computeType, a infraestrutura relevante do CDK ou Terraform será gerada para que você possa implantar seu servidor MCP no Amazon Bedrock AgentCore Runtime.

    Um construct CDK é gerado para você, nomeado com base no name escolhido durante a execução do gerador, ou <ProjectName>McpServer por padrão.

    Você pode usar este construct CDK em uma aplicação CDK:

    import { MyProjectMcpServer } from ':my-scope/common-constructs';
    export class ExampleStack extends Stack {
    constructor(scope: Construct, id: string) {
    // Adicione o servidor MCP à sua stack
    new MyProjectMcpServer(this, 'MyProjectMcpServer');
    }
    }

    Por padrão, seu servidor MCP será protegido usando autenticação IAM. Basta implantá-lo sem argumentos adicionais:

    import { MyProjectMcpServer } from ':my-scope/common-constructs';
    export class ExampleStack extends Stack {
    constructor(scope: Construct, id: string) {
    new MyProjectMcpServer(this, 'MyProjectMcpServer');
    }
    }

    Você pode conceder acesso para invocar seu MCP no Bedrock AgentCore Runtime usando o método grantInvoke. Por exemplo, você pode permitir que um agent gerado com o gerador py#strands-agent chame seu servidor MCP:

    import { MyProjectAgent, MyProjectMcpServer } from ':my-scope/common-constructs';
    export class ExampleStack extends Stack {
    constructor(scope: Construct, id: string) {
    const agent = new MyProjectAgent(this, 'MyProjectAgent');
    const mcpServer = new MyProjectMcpServer(this, 'MyProjectMcpServer');
    mcpServer.agentCoreRuntime.grantInvoke(agent.agentCoreRuntime);
    }
    }

    O exemplo abaixo demonstra como configurar autenticação Cognito para seu agent.

    Para configurar autenticação JWT, você pode passar a propriedade authorizerConfiguration para seu construct de servidor MCP. Aqui está um exemplo que configura um user pool e client Cognito:

    import { MyProjectMcpServer } from ':my-scope/common-constructs';
    export class ExampleStack extends Stack {
    constructor(scope: Construct, id: string) {
    const userPool = new UserPool(this, 'UserPool');
    const client = userPool.addClient('Client', {
    authFlows: {
    userPassword: true,
    },
    });
    new MyProjectMcpServer(this, 'MyProjectMcpServer', {
    authorizerConfiguration: {
    customJWTAuthorizer: {
    discoveryUrl: `https://cognito-idp.${Stack.of(userPool).region}.amazonaws.com/${userPool.userPoolId}/.well-known/openid-configuration`,
    allowedClients: [client.userPoolClientId],
    },
    },
    });
    }
    }

    Para construir seu servidor MCP para o Bedrock AgentCore Runtime, um alvo bundle é adicionado ao seu projeto, que:

    • Exporta suas dependências Python para um arquivo requirements.txt usando uv export
    • Instala dependências para a plataforma alvo (aarch64-manylinux2014) usando uv pip install

    Um alvo docker específico para seu servidor MCP também é adicionado, que:

    • Constrói uma imagem docker a partir do Dockerfile que executa seu servidor MCP na porta 8000, conforme contrato do protocolo MCP

    Seu servidor MCP é configurado automaticamente com observabilidade usando a AWS Distro for Open Telemetry (ADOT), através da configuração de instrumentação automática em seu Dockerfile.

    Você pode encontrar traces no Console AWS do CloudWatch, selecionando “GenAI Observability” no menu. Observe que para que os traces sejam populados, você precisará habilitar o Transaction Search.

    Para mais detalhes, consulte a documentação do AgentCore sobre observabilidade.