Terraform Mcp サーバー
Terraform MCPサーバーは、Terraformエコシステムとのシームレスな統合を提供し、Infrastructure as Code (IaC) 開発のための高度な自動化とインタラクション機能を可能にします。
概要
Terraform MCPサーバーとは?
Terraform MCPサーバーは、インフラストラクチャをコード(IaC)で開発するためのシームレスな統合と高度な自動化機能を提供することにより、Terraformエコシステムを強化するために設計された強力なツールです。これにより、開発者はTerraformの機能を活用して、クラウドリソースのプロビジョニングと管理を自動化し、インフラストラクチャを効率的に管理およびオーケストレーションすることができます。
Terraform MCPサーバーの特徴
- シームレスな統合:Terraform MCPサーバーは、既存のTerraformワークフローとスムーズに統合され、ユーザーが中断することなく現在のインフラストラクチャ管理の慣行を活用できるようにします。
- 高度な自動化:複雑なインフラストラクチャセットアップの管理プロセスを簡素化する高度な自動化機能を提供し、手動介入や潜在的なエラーを減少させます。
- インフラストラクチャをコードとして(IaC):ユーザーがコードを使用してインフラストラクチャを定義できるIaCパラダイムをサポートし、バージョン管理、共有、再利用が可能です。
- スケーラビリティ:サーバーは大規模なデプロイメントを処理できるように設計されており、広範なインフラストラクチャニーズを持つ企業に適しています。
- コミュニティサポート:HashiCorpエコシステムの一部であるため、大規模なユーザーおよび貢献者のコミュニティからの支援とリソースを享受できます。
Terraform MCPサーバーの使用方法
- インストール:まず、好みの環境にTerraform MCPサーバーをインストールします。詳細な手順については公式のインストールガイドに従ってください。
- 設定:サーバーを既存のTerraformセットアップに接続するように設定します。これには、認証の設定やインフラストラクチャ要件の定義が含まれる場合があります。
- インフラストラクチャの定義:Terraform設定ファイルを使用してインフラストラクチャを定義します。必要なリソース、その構成、および依存関係を指定します。
- デプロイ:Terraformコマンドを実行してインフラストラクチャをデプロイします。MCPサーバーは、設定ファイルに定義されたリソースのオーケストレーションと管理を行います。
- 監視と管理:サーバーの監視ツールを利用して、インフラストラクチャのパフォーマンスを追跡し、必要に応じて調整を行います。
よくある質問
Q1: Terraform MCPサーバーの主な目的は何ですか?
A1: Terraform MCPサーバーの主な目的は、インフラストラクチャをコードとして管理するための高度な自動化と統合機能を提供することにより、Terraformエコシステムを強化することです。
Q2: 既存のTerraformプロジェクトでTerraform MCPサーバーを使用できますか?
A2: はい、Terraform MCPサーバーは既存のTerraformプロジェクトとシームレスに統合されるように設計されており、ゼロから始めることなく現在のワークフローを強化できます。
Q3: Terraform MCPサーバーに対するコミュニティサポートはありますか?
A3: もちろんです!Terraform MCPサーバーはHashiCorpエコシステムの一部であり、サポートやリソースを提供する活気あるユーザーおよび貢献者のコミュニティがあります。
Q4: Terraform MCPサーバーはスケーラビリティをどのように扱いますか?
A4: Terraform MCPサーバーは、大規模なデプロイメントを効果的に管理できるように構築されており、パフォーマンスを損なうことなく広範なインフラストラクチャニーズを処理できます。
Q5: Terraform MCPサーバーを使用するための前提条件は何ですか?
A5: ユーザーはTerraformおよびインフラストラクチャをコードとして扱う原則について基本的な理解を持っている必要があります。クラウドサービスプロバイダーやそのAPIに精通していることも有益です。
詳細
<img src="public/images/Terraform-LogoMark_onDark.svg" width="30" align="left" style="margin-right: 12px;"/> Terraform MCP Server
The Terraform MCP Server is a Model Context Protocol (MCP) server that provides seamless integration with Terraform Registry APIs, enabling advanced automation and interaction capabilities for Infrastructure as Code (IaC) development.
Features
- Dual Transport Support: Both Stdio and StreamableHTTP transports
- Terraform Provider Discovery: Query and explore Terraform providers and their documentation
- Module Search & Analysis: Search and retrieve detailed information about Terraform modules
- Registry Integration: Direct integration with Terraform Registry APIs
- Container Ready: Docker support for easy deployment
Caution: The outputs and recommendations provided by the MCP server are generated dynamically and may vary based on the query, model, and the connected MCP server. Users should thoroughly review all outputs/recommendations to ensure they align with their organization's security best practices, cost-efficiency goals, and compliance requirements before implementation.
Prerequisites
- To run the server in a container, you will need to have Docker installed.
- Once Docker is installed, you will need to ensure Docker is running.
Transport Support
The Terraform MCP Server supports multiple transport protocols:
1. Stdio Transport (Default)
Standard input/output communication using JSON-RPC messages. Ideal for local development and direct integration with MCP clients.
2. StreamableHTTP Transport
Modern HTTP-based transport supporting both direct HTTP requests and Server-Sent Events (SSE) streams. This is the recommended transport for remote/distributed setups.
Features:
- Endpoint:
http://{hostname}:8080/mcp
- Health Check:
http://{hostname}:8080/health
- Environment Configuration: Set
MODE=http
orPORT=8080
to enable
Environment Variables:
| Variable | Description | Default |
|-|-||
| MODE
| Set to http
to enable HTTP transport | stdio
|
| PORT
| HTTP server port | 8080
|
Command Line Options
### Stdio mode
terraform-mcp-server stdio [--log-file /path/to/log]
### HTTP mode
terraform-mcp-server http [--port 8080] [--host 0.0.0.0] [--log-file /path/to/log]
Installation
Usage with VS Code
Add the following JSON block to your User Settings (JSON) file in VS Code. You can do this by pressing Ctrl + Shift + P
and typing Preferences: Open User Settings (JSON)
.
More about using MCP server tools in VS Code's agent mode documentation.
{
"mcp": {
"servers": {
"terraform": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"hashicorp/terraform-mcp-server"
]
}
}
}
}
Optionally, you can add a similar example (i.e. without the mcp key) to a file called .vscode/mcp.json
in your workspace. This will allow you to share the configuration with others.
{
"servers": {
"terraform": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"hashicorp/terraform-mcp-server"
]
}
}
}
Usage with Claude Desktop / Amazon Q Developer / Amazon Q CLI
More about using MCP server tools in Claude Desktop user documentation. Read more about using MCP server in Amazon Q from the documentation.
{
"mcpServers": {
"terraform": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"hashicorp/terraform-mcp-server"
]
}
}
}
Tool Configuration
Available Toolsets
The following sets of tools are available:
| Toolset | Tool | Description |
|-||-|
| providers
| resolveProviderDocID
| Queries the Terraform Registry to find and list available documentation for a specific provider using the specified serviceSlug
. Returns a list of provider document IDs with their titles and categories for resources, data sources, functions, or guides. |
| providers
| getProviderDocs
| Fetches the complete documentation content for a specific provider resource, data source, or function using a document ID obtained from the resolveProviderDocID
tool. Returns the raw documentation in markdown format. |
| modules
| searchModules
| Searches the Terraform Registry for modules based on specified moduleQuery
with pagination. Returns a list of module IDs with their names, descriptions, download counts, verification status, and publish dates |
| modules
| moduleDetails
| Retrieves detailed documentation for a module using a module ID obtained from the searchModules
tool including inputs, outputs, configuration, submodules, and examples. |
| policies
| searchPolicies
| Queries the Terraform Registry to find and list the appropriate Sentinel Policy based on the provided query policyQuery
. Returns a list of matching policies with terraformPolicyIDs with their name, title and download counts. |
| policies
| policyDetails
| Retrieves detailed documentation for a policy set using a terraformPolicyID obtained from the searchPolicies
tool including policy readme and implementation details. |
Install from source
Use the latest release version:
go install github.com/hashicorp/terraform-mcp-server/cmd/terraform-mcp-server@latest
Use the main branch:
go install github.com/hashicorp/terraform-mcp-server/cmd/terraform-mcp-server@main
{
"mcp": {
"servers": {
"terraform": {
"command": "/path/to/terraform-mcp-server",
"args": ["stdio"]
}
}
}
}
Building the Docker Image locally
Before using the server, you need to build the Docker image locally:
- Clone the repository:
git clone https://github.com/hashicorp/terraform-mcp-server.git
cd terraform-mcp-server
- Build the Docker image:
make docker-build
- This will create a local Docker image that you can use in the following configuration.
### Run in stdio mode
docker run -i --rm terraform-mcp-server:dev
### Run in http mode
docker run -p 8080:8080 --rm -e MODE=http terraform-mcp-server:dev
- (Optional) Test connection in http mode
### Test the connection
curl http://localhost:8080/health
- You can use it on your AI assistant as follow:
{
"mcpServers": {
"terraform": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"terraform-mcp-server:dev"
]
}
}
}
Development
Prerequisites
- Go (check go.mod file for specific version)
- Docker (optional, for container builds)
Available Make Commands
| Command | Description |
||-|
| make build
| Build the binary |
| make test
| Run all tests |
| make test-e2e
| Run end-to-end tests |
| make docker-build
| Build Docker image |
| make run-http
| Run HTTP server locally |
| make docker-run-http
| Run HTTP server in Docker |
| make test-http
| Test HTTP health endpoint |
| make clean
| Remove build artifacts |
| make help
| Show all available commands |
Contributing
- Fork the repository
- Create your feature branch
- Make your changes
- Run tests
- Submit a pull request
License
This project is licensed under the terms of the MPL-2.0 open source license. Please refer to LICENSE file for the full terms.
Security
For security issues, please contact security@hashicorp.com or follow our security policy.
Support
For bug reports and feature requests, please open an issue on GitHub.
For general questions and discussions, open a GitHub Discussion.
サーバー設定
{
"mcp": {
"servers": {
"terraform": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"hashicorp/terraform-mcp-server"
]
}
}
}
}