Catalog
github/aws-cost-optimize

github

aws-cost-optimize

Analyze AWS resources used in the app (IaC files and/or resources in a target account/region) and optimize costs - creating GitHub issues for identified optimizations.

global
New~2.0k
v1.0Saved Jun 26, 2026

AWS Cost Optimize

This workflow analyzes Infrastructure-as-Code (IaC) files and AWS resources to generate cost optimization recommendations. It creates individual GitHub issues for each optimization opportunity plus one EPIC issue to coordinate implementation, enabling efficient tracking and execution of cost savings initiatives.

Prerequisites

  • AWS CLI configured and authenticated (aws sts get-caller-identity succeeds)
  • GitHub MCP server configured and authenticated
  • Target GitHub repository identified
  • AWS resources deployed (IaC files optional but helpful)

Workflow Steps

Step 1: Get AWS Cost Optimization Best Practices

Action: Retrieve cost optimization best practices before analysis Tools: fetch to retrieve AWS documentation Process:

  1. Load Best Practices:
    • Fetch https://docs.aws.amazon.com/cost-management/latest/userguide/cost-optimization-best-practices.html
    • Fetch the AWS Well-Architected Cost Optimization pillar summary
    • Use these practices to inform subsequent analysis and recommendations

Step 2: Discover AWS Infrastructure

Action: Dynamically discover and analyze AWS resources and configurations Tools: AWS CLI + Local file system access Process:

  1. Account & Region Discovery:

    • Execute aws sts get-caller-identity to confirm account
    • Execute aws configure get region to determine default region
  2. Resource Discovery (per region):

    • EC2 instances: aws ec2 describe-instances --query 'Reservations[].Instances[].[InstanceId,InstanceType,State.Name,Tags]'
    • RDS instances: aws rds describe-db-instances --query 'DBInstances[].[DBInstanceIdentifier,DBInstanceClass,Engine,MultiAZ]'
    • Lambda functions: aws lambda list-functions --query 'Functions[].[FunctionName,Runtime,MemorySize,Architectures]'
    • ECS clusters/services: aws ecs list-clusters then aws ecs describe-services
    • S3 buckets: aws s3api list-buckets --query 'Buckets[].Name'
    • ElastiCache clusters: aws elasticache describe-cache-clusters
    • NAT Gateways: aws ec2 describe-nat-gateways
    • Load Balancers: aws elbv2 describe-load-balancers
  3. IaC Detection:

    • Scan for IaC files: **/*.tf, **/*.yaml (CloudFormation/SAM), **/*.json (CloudFormation), **/cdk.json, lib/**/*.ts (CDK)
    • Parse resource definitions to understand intended configurations
    • Do NOT use application code files — only IaC files as the source of truth
    • If no IaC files found: STOP and report to user

Step 3: Collect Usage Metrics & Validate Current Costs

Action: Gather utilization data and verify actual resource costs Tools: AWS CLI (CloudWatch, Cost Explorer) Process:

  1. CloudWatch Metrics (last 7 days):

    # EC2 CPU utilization
    aws cloudwatch get-metric-statistics \
      --namespace AWS/EC2 --metric-name CPUUtilization \
      --dimensions Name=InstanceId,Value=<id> \
      --start-time $(date -u -d '7 days ago' +%Y-%m-%dT%H:%M:%SZ) \
      --end-time $(date -u +%Y-%m-%dT%H:%M:%SZ) \
      --period 3600 --statistics Average
    
    # Lambda duration
    aws cloudwatch get-metric-statistics \
      --namespace AWS/Lambda --metric-name Duration \
      --dimensions Name=FunctionName,Value=<name> \
      --start-time $(date -u -d '7 days ago' +%Y-%m-%dT%H:%M:%SZ) \
      --end-time $(date -u +%Y-%m-%dT%H:%M:%SZ) \
      --period 86400 --statistics Average,Maximum
    
  2. AWS Cost Explorer:

    aws ce get-cost-and-usage \
      --time-period Start=$(date -u -d '30 days ago' +%Y-%m-%d),End=$(date -u +%Y-%m-%d) \
      --granularity MONTHLY --metrics BlendedCost \
      --group-by Type=DIMENSION,Key=SERVICE
    
  3. Calculate Baseline Metrics: CPU/Memory averages, Lambda invocation rates, data transfer patterns, and a realistic current monthly total.

Step 4: Generate Cost Optimization Recommendations

Action: Analyze resources to identify optimization opportunities Process:

  1. Apply Optimization Patterns:

    Compute:

    • EC2: Right-size based on CPU/memory (<20% average → downsize), convert On-Demand to Savings Plans, migrate to Graviton/ARM (up to 40% cheaper)
    • Lambda: Reduce memory for idle functions, switch to arm64 (20% cheaper)
    • ECS/EKS: Use Fargate Spot for dev/batch workloads

    Database:

    • RDS: Right-size instance class, convert single-AZ for dev, use Aurora Serverless v2 for variable load
    • DynamoDB: Switch Provisioned → On-Demand for unpredictable traffic
    • ElastiCache: Right-size node type based on memory utilization

    Storage:

    • S3: Lifecycle policies (Standard → Standard-IA after 30d → Glacier after 90d), enable Intelligent-Tiering
    • EBS: Delete unattached volumes, convert gp2 → gp3 (same performance, 20% cheaper)

    Network:

    • Consolidate NAT Gateways for non-production environments
    • Use VPC endpoints for S3/DynamoDB to avoid NAT Gateway charges
  2. Calculate Priority Score:

    Priority Score = (Value Score × Monthly Savings) / (Risk Score × Implementation Days)
    High: Score > 20 | Medium: Score 5-20 | Low: Score < 5
    

Step 5: User Confirmation

Action: Present summary and get approval before creating GitHub issues

🎯 AWS Cost Optimization Summary

📊 Analysis Results:
• Total Resources Analyzed: X
• Current Monthly Cost: $X
• Potential Monthly Savings: $Y
• Optimization Opportunities: Z
• High Priority Items: N

🏆 Recommendations:
1. [Resource]: [Current] → [Target] = $X/month savings - [Risk] | [Effort]
...

💡 This will create Y individual GitHub issues + 1 EPIC issue.

❓ Proceed with creating GitHub issues? (y/n)

Wait for user confirmation before proceeding.

Step 6: Create Individual Optimization Issues

Action: Create separate GitHub issues for each optimization. Label with "cost-optimization" (green) and "aws" (orange).

Title: [COST-OPT] [Resource Type] - [Brief Description] - $X/month savings

Body:

## 💰 Cost Optimization: [Brief Title]

**Monthly Savings**: $X | **Risk Level**: [Low/Medium/High] | **Effort**: X days

### 📋 Description
[Clear explanation of the optimization and why it's needed]

### 🔧 Implementation

**IaC Files Detected**: [Yes/No]

```bash
# IaC modification (preferred) or AWS CLI fallback

📊 Evidence

  • Current Configuration: [details]
  • Usage Pattern: [evidence from CloudWatch]
  • Cost Impact: $X/month → $Y/month

✅ Validation Steps

  • Test in non-production environment
  • Verify no performance degradation via CloudWatch
  • Confirm cost reduction in AWS Cost Explorer

⚠️ Risks & Considerations

  • [Risk and mitigation]

Priority Score: X | Value: X/10 | Risk: X/10


### Step 7: Create EPIC Coordinating Issue
**Action**: Create master tracking issue. Label with "cost-optimization" (green), "aws" (orange), "epic" (purple).

**Title**: `[EPIC] AWS Cost Optimization Initiative - $X/month potential savings`

**Body**: Executive summary with account/region details, Mermaid architecture diagram of current resources, prioritized checklist linking all individual issues (High → Medium → Low), progress tracking, and success criteria (>80% of estimated savings realized, no performance degradation).

## Error Handling
- **AWS Authentication Failure**: Guide through `aws configure`
- **No Resources Found**: Create informational issue about AWS resource deployment
- **Insufficient Permissions**: List required IAM read-only permissions
- **GitHub Creation Failure**: Output formatted recommendations to console
- **Cost Explorer Not Enabled**: Guide user to enable in AWS Console

## Success Criteria
- ✅ All cost estimates verified against actual configurations and AWS pricing
- ✅ Individual GitHub issues created for each optimization
- ✅ EPIC issue provides comprehensive coordination and tracking
- ✅ All recommendations include specific AWS CLI or IaC commands
- ✅ User confirmation obtained before creating issues
Files1
1 files · 1.0 KB

Select a file to preview

Overall Score

78/100

Grade

B

Good

Safety

80

Quality

82

Clarity

76

Completeness

72

Summary

This skill guides an AI agent to analyze AWS infrastructure and generate cost optimization recommendations by querying IaC files and AWS resources, then creating GitHub issues for each optimization opportunity plus a coordinating EPIC issue. The workflow combines AWS CLI queries, CloudWatch metrics collection, documentation fetching, and GitHub issue creation to streamline cost optimization tracking.

Detected Capabilities

aws-cli-executionfile-readingcloudwatch-metrics-collectioncost-explorer-queriesgithub-issue-creationhttp-fetchjson-parsingbash-command-execution

Trigger Keywords

Phrases that MCP clients use to match this skill to user intent.

optimize aws costsanalyze cloud expensesright-size ec2 instancess3 lifecycle policiesrds cost reductioncreate optimization issues

Risk Signals

INFO

AWS CLI commands execute read-only queries against user's AWS account

Step 2: Discover AWS Infrastructure
INFO

Fetches public AWS documentation from docs.aws.amazon.com

Step 1: Get AWS Cost Optimization Best Practices
INFO

Reads IaC files from local filesystem (**/*.tf, **/*.yaml, **/*.json, etc.)

Step 2: IaC Detection
INFO

Creates GitHub issues using authenticated GitHub MCP server

Step 6 & 7: GitHub Issue Creation
WARNING

Executes AWS CLI commands with dynamic parameters (resource IDs from discovery phase)

Step 3: CloudWatch metrics collection

Referenced Domains

External domains referenced in skill content, detected by static analysis.

docs.aws.amazon.com

Use Cases

  • Identify underutilized EC2 instances for right-sizing
  • Recommend storage lifecycle policies for S3 buckets
  • Detect RDS instances that can be converted to serverless alternatives
  • Consolidate NAT Gateways in non-production environments
  • Create prioritized GitHub issues for cost optimization implementation
  • Track cost savings initiatives across teams using GitHub EPIC issues

Quality Notes

  • ✅ Clear prerequisite section documents required AWS/GitHub authentication and tool setup
  • ✅ Step-by-step workflow is well-organized with specific CLI commands and expected outputs
  • ✅ Comprehensive error handling section covers authentication, permissions, and common failures
  • ✅ Concrete calculation methodology for priority scoring enables consistent recommendations
  • ✅ Explicit boundary: 'Do NOT use application code files — only IaC files as the source of truth' prevents scope creep
  • ✅ User confirmation gate (Step 5) prevents unintended GitHub issue creation
  • ✅ Success criteria are measurable and tied to cost accuracy and resource coverage
  • ⚠️ Step 3 uses CloudWatch metrics with hardcoded 7-day window (could be parameterized)
  • ⚠️ No guidance on handling multiple AWS accounts or cross-region optimization prioritization
  • ⚠️ Risk assessment in recommendations ('Low/Medium/High') lacks explicit criteria or scoring rubric
Model: claude-haiku-4-5-20251001Analyzed: Jun 26, 2026

Reviews

Add this skill to your library to leave a review.

No reviews yet

Be the first to share your experience.

Add github/aws-cost-optimize to your library

Command Palette

Search for a command to run...