Steampipe Model Context Protocol (MCP) Server
Unlock the power of AI-driven infrastructure analysis with Steampipe! This Model Context Protocol server seamlessly connects AI assistants like Claude to your cloud infrastructure data, enabling natural language exploration and analysis of your entire cloud estate.
Steampipe MCP bridges AI assistants and your infrastructure data, allowing natural language:
- Queries across AWS, Azure, GCP and 100+ cloud services
- Security and compliance analysis
- Cost and resource optimization
- Query development assistance
Works with both local Steampipe installations and Turbot Pipes workspaces, providing safe, read-only access to all your cloud and SaaS data.
Installation
Prerequisites
- Node.js v16 or higher (includes
npx
) - For local use: Steampipe installed and running (
steampipe service start
) - For Turbot Pipes: A Turbot Pipes workspace and connection string
Configuration
Add Steampipe MCP to your AI assistant's configuration file:
By default, this connects to your local Steampipe installation at postgresql://steampipe@localhost:9193/steampipe
. Make sure to run steampipe service start
first.
To connect to a Turbot Pipes workspace instead, add your connection string to the args:
AI Assistant Setup
Assistant | Config File Location | Setup Guide |
---|---|---|
Claude Desktop | claude_desktop_config.json | Claude Desktop MCP Guide → |
Cursor | ~/.cursor/mcp.json | Cursor MCP Guide → |
Save the configuration file and restart your AI assistant for the changes to take effect.
Prompting Guide
First, run the best_practices
prompt included in the MCP server to teach your LLM how best to work with Steampipe. Then, ask anything!
Explore your cloud infrastructure:
Simple, specific questions work well:
Generate infrastructure reports:
Dive into security analysis:
Get compliance insights:
Explore potential risks:
Remember to:
- Be specific about which cloud resources you want to analyze (EC2, S3, IAM, etc.)
- Mention regions or accounts if you're interested in specific ones
- Start with simple queries before adding complex conditions
- Use natural language - the LLM will handle the SQL translation
- Be bold and exploratory - the LLM can help you discover insights across your entire infrastructure!
Capabilities
Tools
- steampipe_query
- Query cloud and security logs with SQL.
- For best performance: use CTEs instead of joins, limit columns requested.
- All queries are read-only and use PostgreSQL syntax.
- Input:
sql
(string): The SQL query to execute using PostgreSQL syntax
- steampipe_table_list
- List all available Steampipe tables.
- Optional input:
schema
(string): Filter tables by specific schema - Optional input:
filter
(string): Filter tables by ILIKE pattern (e.g. 'ì2%')
- steampipe_table_show
- Get detailed information about a specific table, including column definitions, data types, and descriptions.
- Input:
name
(string): The name of the table to show details for (can be schema qualified e.g. 'aws_account' or 'aws.aws_account') - Optional input:
schema
(string): The schema containing the table
- steampipe_plugin_list
- List all Steampipe plugins installed on the system. Plugins provide access to different data sources like AWS, GCP, or Azure.
- No input parameters required
- steampipe_plugin_show
- Get details for a specific Steampipe plugin installation, including version, memory limits, and configuration.
- Input:
name
(string): Name of the plugin to show details for
Prompts
- best_practices
- Best practices for working with Steampipe data
- Provides detailed guidance on:
- Response style and formatting conventions
- Using CTEs (WITH clauses) vs joins
- SQL syntax and style conventions
- Column selection and optimization
- Schema exploration and understanding
- Query structure and organization
- Performance considerations and caching
- Error handling and troubleshooting
Resources
- status
- Represents the current state of the Steampipe connection
- Properties include:
- connection_string: The current database connection string
- status: The connection state (connected/disconnected)
This resource enables AI tools to check and verify the connection status to your Steampipe instance.
Development
Clone and Setup
- Clone the repository and navigate to the directory:
- Install dependencies:
- Build the project:
Testing
To test your local development build with AI tools that support MCP, update your MCP configuration to use the local dist/index.js
instead of the npm package. For example:
Or, use the MCP Inspector to validate the server implementation:
Environment Variables
The following environment variables can be used to configure the MCP server:
STEAMPIPE_MCP_LOG_LEVEL
: Control server logging verbosity (default:info
)STEAMPIPE_MCP_WORKSPACE_DATABASE
: Override the default Steampipe connection string (default:postgresql://steampipe@localhost:9193/steampipe
)
Open Source & Contributing
This repository is published under the Apache 2.0 license. Please see our code of conduct. We look forward to collaborating with you!
Steampipe is a product produced from this open source software, exclusively by Turbot HQ, Inc. It is distributed under our commercial terms. Others are allowed to make their own distribution of the software, but they cannot use any of the Turbot trademarks, cloud services, etc. You can learn more in our Open Source FAQ.
Get Involved
Want to help but don't know where to start? Pick up one of the help wanted
issues:
Related MCP Servers
- -securityFlicense-qualityAn MCP server that connects Claude to FL Studio, allowing the AI to compose music, control instruments, and live record melodies, chords, and drums to the piano roll.Last updated -8Python
- -security-license-qualityThis is an MCP written for steampipe. This Steampipe MCP tool allows Claude to interact directly with your Steampipe installation using natural language requests. It executes provided SQL queries via the Steampipe CLI and returns the data results as JSON back to Claude.Last updated -PythonMIT License
- Python
- MIT License