Python Strands Agent から MCP へ
connection ジェネレーターは、Python Strands Agent を MCP サーバー(TypeScript または Python)に接続できます。
このジェネレーターは、エージェントが MCP サーバーのツールを検出して呼び出すために必要なすべての配線を設定します。これは、AWS にデプロイされた場合(Bedrock AgentCore 経由)とローカルで実行される場合の両方で機能します。
このジェネレーターを使用する前に、以下を確認してください:
- Strands Agent コンポーネントを含む Python プロジェクト
- MCP サーバーコンポーネント(
ts#mcp-serverまたはpy#mcp-server)を含むプロジェクト - 両方のコンポーネントが
computeType: BedrockAgentCoreRuntimeで作成されていること
ジェネレーターの実行
Section titled “ジェネレーターの実行”- インストール Nx Console VSCode Plugin まだインストールしていない場合
- VSCodeでNxコンソールを開く
- クリック
Generate (UI)"Common Nx Commands"セクションで - 検索
@aws/nx-plugin - connection - 必須パラメータを入力
- クリック
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:connectionエージェントプロジェクトをソースとして、MCP サーバープロジェクトをターゲットとして選択します。プロジェクトに複数のコンポーネントが含まれている場合は、sourceComponent と targetComponent オプションを指定して明確にします。
| パラメータ | 型 | デフォルト | 説明 |
|---|---|---|---|
| sourceProject 必須 | string | - | ソース プロジェクト |
| targetProject 必須 | string | - | 接続先のターゲット プロジェクト |
| sourceComponent | string | - | 接続元のソース コンポーネント (コンポーネント名、ソース プロジェクト ルートからの相対パス、またはジェネレーター ID)。プロジェクトをソースとして明示的に選択するには '.' を使用します。 |
| targetComponent | string | - | 接続先のターゲット コンポーネント (コンポーネント名、ターゲット プロジェクト ルートからの相対パス、またはジェネレーター ID)。プロジェクトをターゲットとして明示的に選択するには '.' を使用します。 |
ジェネレーターの出力
Section titled “ジェネレーターの出力”ジェネレーターは、packages/common/agent_connection/ に共有の agent_connection Python プロジェクトを作成します(まだ存在しない場合)。接続ごとのクライアントモジュールがこの共有プロジェクトに生成されます:
Directorypackages/common/agent_connection
Directory<scope>_agent_connection
- __init__.py 接続ごとのクライアントを再エクスポート
Directorycore
- agentcore_mcp_client.py コア AgentCore MCP クライアント
Directoryapp
- <mcp_server_name>_client.py 各 MCP サーバーの接続ごとのクライアント
さらに、ジェネレーターは以下を行います:
- エージェントの
agent.pyを変換して、クラスベースのクライアント経由で MCP サーバーのツールをインポートして使用 agent_connectionプロジェクトをエージェントプロジェクトのワークスペース依存関係として追加- エージェントの
serve-localターゲットを更新して、MCP サーバーの serve ターゲットに依存するようにする
接続された MCP サーバーの使用
Section titled “接続された MCP サーバーの使用”ジェネレーターは、エージェントの agent.py を変換して 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()], )session_id パラメーターは呼び出し元から渡され、Bedrock AgentCore Observability の一貫性を保証します。
インフラストラクチャ
Section titled “インフラストラクチャ”接続ジェネレーターを実行した後、エージェントに 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);MCP サーバーの AgentCore ランタイム ARN は、生成された CDK コンストラクトによって ランタイム設定 の connection 名前空間に自動的に登録されるため、エージェントは実行時にそれを検出できます。
接続ジェネレーターを実行した後、Terraform 設定でエージェントに MCP サーバーを呼び出す権限を付与する必要があります:
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}MCP サーバーの AgentCore ランタイム ARN は、生成された Terraform モジュールによって ランタイム設定 の connection 名前空間に自動的に登録されるため、エージェントは実行時にそれを検出できます。
ローカル開発
Section titled “ローカル開発”ジェネレーターは、エージェントの serve-local ターゲットを以下のように設定します:
- 接続された MCP サーバーを自動的に起動
SERVE_LOCAL=trueを設定して、生成されたクライアントが AgentCore の代わりに直接 HTTP トランスポートを使用するようにする
エージェントをローカルで実行するには:
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>これにより、エージェントとすべての接続された MCP サーバーの両方が起動し、エージェントは割り当てられたローカルポートで HTTP 経由で MCP サーバーに直接接続します。