
prometheus-mcp
Provides seamless integration between AI assistants and Prometheus, enabling natural language interactions with your monitoring infrastructure. This server allows for effortless querying, discovery, and analysis of metrics.
README
<h1 align="center" style="border-bottom: none"> <img src="./assets/icon.png" alt="Prometheus MCP Logo"><br>Prometheus MCP Server </h1>
<div align="center">
A Model Context Protocol (MCP) server that provides seamless integration between AI assistants and Prometheus, enabling natural language interactions with your monitoring infrastructure. This server allows for effortless querying, discovery, and analysis of metrics through Visual Studio Code, Cursor, Windsurf, Claude Desktop, and other MCP clients.
</div>
Key Features
- Fast and lightweight. Direct API integration with Prometheus, no complex parsing needed.
- LLM-friendly. Structured JSON responses optimized for AI assistant consumption.
- Configurable capabilities. Enable/disable tool categories based on your security and operational requirements.
- Dual transport support. Works with both stdio and HTTP transports for maximum compatibility.
Requirements
- Node.js 20.19.0 or newer
- Access to a Prometheus server
- VS Code, Cursor, Windsurf, Claude Desktop or any other MCP client
Getting Started
First, install the Prometheus MCP server with your client. A typical configuration looks like this:
{
"mcpServers": {
"prometheus": {
"command": "npx",
"args": ["prometheus-mcp@latest", "stdio"],
"env": {
"PROMETHEUS_URL": "http://localhost:9090"
}
}
}
}
<details><summary><b>Install in VS Code</b></summary>
# For VS Code
code --add-mcp '{"name":"prometheus","command":"npx","args":["prometheus-mcp@latest","stdio"],"env":{"PROMETHEUS_URL":"http://localhost:9090"}}'
# For VS Code Insiders
code-insiders --add-mcp '{"name":"prometheus","command":"npx","args":["prometheus-mcp@latest","stdio"],"env":{"PROMETHEUS_URL":"http://localhost:9090"}}'
After installation, the Prometheus MCP server will be available for use with your GitHub Copilot agent in VS Code.
</details>
<details><summary><b>Install in Cursor</b></summary>
Go to Cursor Settings
→ MCP
→ Add new MCP Server
. Name to your liking, use command
type with the command npx prometheus-mcp
. You can also verify config or add command arguments via clicking Edit
.
{
"mcpServers": {
"prometheus": {
"command": "npx",
"args": ["prometheus-mcp@latest", "stdio"],
"env": {
"PROMETHEUS_URL": "http://localhost:9090"
}
}
}
}
</details>
<details><summary><b>Install in Windsurf</b></summary>
Follow Windsurf MCP documentation. Use the following configuration:
{
"mcpServers": {
"prometheus": {
"command": "npx",
"args": ["prometheus-mcp@latest", "stdio"],
"env": {
"PROMETHEUS_URL": "http://localhost:9090"
}
}
}
}
</details>
<details><summary><b>Install in Claude Desktop</b></summary>
Claude Desktop supports two installation methods:
Option 1: DXT Extension
The easiest way to install is using the pre-built DXT extension:
- Download the latest
.dxt
file from the releases page - Double-click the downloaded file to install automatically
- Configure your Prometheus URL in the extension settings
Option 2: Developer Settings
For advanced users or custom configurations, manually configure the MCP server:
- Open Claude Desktop settings
- Navigate to the Developer section
- Add the following MCP server configuration:
{
"mcpServers": {
"prometheus": {
"command": "npx",
"args": ["prometheus-mcp@latest", "stdio"],
"env": {
"PROMETHEUS_URL": "http://localhost:9090"
}
}
}
}
</details>
Configuration
Prometheus MCP server supports the following arguments. They can be provided in the JSON configuration above, as part of the "args"
list:
> npx prometheus-mcp@latest --help
Commands:
stdio Start Prometheus MCP server using stdio transport
http Start Prometheus MCP server using HTTP transport
Options:
--help Show help [boolean]
--version Show version number [boolean]
Environment Variables
You can also configure the server using environment variables:
PROMETHEUS_URL
- Prometheus server URLENABLE_DISCOVERY_TOOLS
- Set to "false" to disable discovery tools (default: true)ENABLE_INFO_TOOLS
- Set to "false" to disable info tools (default: true)ENABLE_QUERY_TOOLS
- Set to "false" to disable query tools (default: true)
Standalone MCP Server
When running in server environments or when you need HTTP transport, run the MCP server with the http
command:
npx prometheus-mcp@latest http --port 3000
And then in your MCP client config, set the url
to the HTTP endpoint:
{
"mcpServers": {
"prometheus": {
"command": "npx",
"args": ["mcp-remote", "http://localhost:3000/mcp"]
}
}
}
Docker
Run the Prometheus MCP server using Docker:
{
"mcpServers": {
"prometheus": {
"command": "docker",
"args": [
"run",
"-i",
"--rm",
"--init",
"--pull=always",
"-e",
"PROMETHEUS_URL=http://host.docker.internal:9090",
"ghcr.io/idanfishman/prometheus-mcp",
"stdio"
]
}
}
}
Tools
The Prometheus MCP server provides 10 tools organized into three configurable categories:
<details><summary><b>Discovery</b></summary>
Tools for exploring your Prometheus infrastructure:
-
prometheus_list_metrics
- Description: List all available Prometheus metrics
- Parameters: None
- Read-only: true
-
prometheus_metric_metadata
- Description: Get metadata for a specific Prometheus metric
- Parameters:
metric
(string): Metric name to get metadata for
- Read-only: true
-
prometheus_list_labels
- Description: List all available Prometheus labels
- Parameters: None
- Read-only: true
-
prometheus_label_values
- Description: Get all values for a specific Prometheus label
- Parameters:
label
(string): Label name to get values for
- Read-only: true
-
prometheus_list_targets
- Description: List all Prometheus scrape targets
- Parameters: None
- Read-only: true
-
prometheus_scrape_pool_targets
- Description: Get targets for a specific scrape pool
- Parameters:
scrapePool
(string): Scrape pool name
- Read-only: true
</details>
<details><summary><b>Info</b></summary>
Tools for accessing Prometheus server information:
-
prometheus_runtime_info
- Description: Get Prometheus runtime information
- Parameters: None
- Read-only: true
-
prometheus_build_info
- Description: Get Prometheus build information
- Parameters: None
- Read-only: true
</details>
<details><summary><b>Query</b></summary>
Tools for executing Prometheus queries:
-
prometheus_query
- Description: Execute an instant Prometheus query
- Parameters:
query
(string): Prometheus query expressiontime
(string, optional): Time parameter for the query (RFC3339 format)
- Read-only: true
-
prometheus_query_range
- Description: Execute a Prometheus range query
- Parameters:
query
(string): Prometheus query expressionstart
(string): Start timestamp (RFC3339 or unix timestamp)end
(string): End timestamp (RFC3339 or unix timestamp)step
(string): Query resolution step width
- Read-only: true
</details>
Example Usage
Here are some example interactions you can have with your AI assistant:
Basic Queries
- "Show me all available metrics in Prometheus"
- "What's the current CPU usage across all instances?"
- "Get the memory usage for the last hour"
Discovery and Exploration
- "List all scrape targets and their status"
- "What labels are available for the
http_requests_total
metric?" - "Show me all metrics related to 'cpu'"
Advanced Analysis
- "Compare CPU usage between production and staging environments"
- "Show me the top 10 services by memory consumption"
- "What's the error rate trend for the API service over the last 24 hours?"
Security Considerations
- Network Access: The server requires network access to your Prometheus instance
- Resource Usage: Range queries can be resource-intensive; monitor your Prometheus server load
Troubleshooting
Connection Issues
- Verify your Prometheus server is accessible at the configured URL
- Check firewall settings and network connectivity
- Ensure Prometheus API is enabled (default on port 9090)
Permission Errors
- Verify the MCP server has network access to Prometheus
- Check if authentication is required for your Prometheus setup
Tool Availability
- If certain tools are missing, check if they've been disabled via configuration
License
This project is licensed under the MIT License - see the LICENSE file for details.
Support
- GitHub Issues: Report bugs or request features
- Documentation: Model Context Protocol Documentation
- Prometheus: Prometheus Documentation
Built with ❤️ for the Prometheus and MCP communities
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.

VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.

E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.