aws-cost-explorer
Enables AI assistants to query and analyze AWS costs and usage via the Cost Explorer API.
README
AWS Cost Explorer MCP Server
A Python-based Model Context Protocol (MCP) server that provides tools for accessing AWS Cost Explorer data. This server enables AI assistants like Claude to query and analyze your AWS costs and usage.
Features
- Cost and Usage Analysis: Get detailed cost breakdowns by time period
- Dimension Values: Discover available services, regions, accounts, etc.
- Flexible Filtering: Filter costs by various dimensions
- Multiple Metrics: Support for different cost metrics (UnblendedCost, AmortizedCost, etc.)
- Secure Authentication: Uses AWS profiles or environment variables
Prerequisites
- Python 3.8 or higher
- AWS account with Cost Explorer access
- AWS credentials configured (via AWS CLI, environment variables, or IAM roles)
Installation
-
Clone or download this repository
-
Install dependencies:
pip install -r requirements.txt -
Configure AWS credentials (choose one method):
Option A: AWS CLI Profile
aws configure --profile your-profile-nameOption B: Environment Variables
export AWS_ACCESS_KEY_ID=your_access_key export AWS_SECRET_ACCESS_KEY=your_secret_key export AWS_DEFAULT_REGION=us-east-1Option C: Use .env file
cp .env.example .env # Edit .env with your credentials
Usage
Running the Server
python aws_mcp/main.py
The server will start and listen for MCP connections on stdio.
Connecting with Claude Desktop
Add the following to your Claude Desktop configuration file:
macOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"aws-cost-explorer": {
"command": "uv",
"args": [
"--directory",
"/absolute/path/to/aws_mcp",
"run",
"aws-cost-explorer",
"--profile",
"dev"
],
}
}
}
Available Tools
1. get_cost_and_usage
Get AWS costs for a specified time period with optional grouping and filtering.
Parameters:
start(optional): Start date (YYYY-MM-DD, inclusive)end(optional): End date (YYYY-MM-DD, exclusive)granularity: Time granularity - "DAILY" or "MONTHLY" (default: "MONTHLY")group_by(optional): List of dimensions to group by (max 2)metrics(optional): List of cost metrics (default: ["UnblendedCost"])filter_config(optional): Filter by dimension and valuesmax_results: Maximum results (1-100, default: 100)profile(optional): AWS profile name
Example Usage:
"What were my AWS costs last month by service?"
"Show me daily costs for the last 30 days"
"Get costs by region for this year"
2. get_dimension_values
Get available values for a specific Cost Explorer dimension (services, regions, etc.).
Parameters:
dimension: The dimension name (SERVICE, REGION, LINKED_ACCOUNT, etc.)time_period_start(optional): Start date for searchtime_period_end(optional): End date for searchsearch_string(optional): Filter dimension valuesmax_results: Maximum results (1-1000, default: 50)profile(optional): AWS profile name
Example Usage:
"What AWS services am I using?"
"Show me all available regions in my account"
"List my linked accounts"
Supported Dimensions
- SERVICE
- LINKED_ACCOUNT
- REGION
- USAGE_TYPE
- OPERATION
- INSTANCE_TYPE
- PURCHASE_TYPE
- RECORD_TYPE
Supported Metrics
- UnblendedCost
- AmortizedCost
- NetAmortizedCost
- NetUnblendedCost
- NormalizedUsageAmount
- UsageQuantity
- BlendedCost
Security Considerations
- This server requires read access to AWS Cost Explorer
- Use least-privilege IAM policies
- Store credentials securely using AWS best practices
- Consider using IAM roles for EC2/Lambda deployments
Required AWS Permissions
Your AWS credentials need the following permissions:
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Action": [
"ce:GetCostAndUsage",
"ce:GetDimensionValues"
],
"Resource": "*"
}
]
}
Troubleshooting
Common Issues
-
"No credentials found"
- Ensure AWS credentials are properly configured
- Check that the profile name is correct (if using profiles)
-
"Access denied"
- Verify IAM permissions for Cost Explorer
- Ensure billing access is enabled for your account
-
"Invalid date format"
- Use YYYY-MM-DD format for dates
- Ensure end date is after start date
Testing
The server includes a test script to verify functionality:
# Basic functionality test (with credentials configured)
python test_server.py
Expected output when working correctly:
Initializing connection...
Available tools: ['get_cost_and_usage', 'get_dimension_values']
Testing get_cost_and_usage tool...
If you see "Unable to locate credentials", configure AWS credentials as described in the Configuration section above.
Development
To extend this server:
- Add new tools using the
@server.tool()decorator - Follow the MCP protocol specifications
- Use proper error handling for AWS API calls
- Test with different AWS account configurations
License
This project is open source. See LICENSE file for details.
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.