aws-ipv4-cost-viewer

command module
v0.0.0-...-10f6737 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jan 16, 2024 License: OSL-3.0 Imports: 24 Imported by: 0

README

AWS IPv4 Costs Viewer

This tool shows the future public IPv4 costs for a variety of AWS resources (see below) across all AWS regions from an account in a user-friendly terminal UI.

Background

As of February 2024, AWS starts charging 3.65 USD monthly for each public IPv4 address. We will get charged regardless if we provision the IP ourselves or if AWS services provision IPv4 IPs on our behalf, such as for Load balancers.

AWS also offers a similar dashboard in the AWS console, and such data is available also in the cost visibility dashboards, but we try to also provide costs and even utilization metrics for some resources, which allow AWS customers to take more informed optimization actions. And the fact that this is open-source software makes it easier to integrate into different tools.

Features

  • Fetch and display the future IPv4 costs associated with:
    • EC2 Instances
    • Elastic IPs (EIPs)
    • Load Balancers (LBs)
    • Elastic Network Interfaces (ENIs)
  • Interactive terminal UI to navigate through the data.
  • Shows ELB metrics such as the amount of network traffic over the last 7 days, to inform optimization actions.
  • IPv4 addresses for load balancers are determined through the DNS resolution of their public FQDN.
  • Data is fetched in parallel across regions and services for faster results.
  • Name tags are shown wherever possible, with failover to tags created automatically by ASGs and CloudFormation stacks.

Further improvement ideas (contributions welcome)

  • Add support for more resources included in the ENI list. (e.g. ECS, APIGW, etc.), see here for more details.
  • Add support for additional resources not included in the ENI list. (e.g. VPN endpoints, etc.)
  • Properly integrate the subnets view currently available when running with --subnets.
  • Add support to dump data as CSV, JSON, YAML, XLSX, and whatever other file types may make sense.
  • Add some nice anonymized screenshots to the Readme file. (DONE)

Prerequisites

  • Go (1.16 or later)
  • AWS CLI credentials set in the shell environment, for a user/role configured with appropriate permissions.

Installation

go install github.com/leanercloud/aws-ipv4-cost-viewer@latest

Usage

After installation, you can run the tool with:

aws-ipv4-costs-viewer

Navigate through the UI using the arrow keys. Press ESC to exit.

Check out our other open-source projects

For more advanced features of some of these tools, as well as comprehensive cost optimization services focused on AWS, visit our commercial offerings at LeanerCloud.com.

We're also working on an automated RDS rightsizing tool that converts DBs to Graviton instance types and GP3 storage. If you're interested to learn more about it, reach out to us on Slack.

Contributing

We welcome contributions! Please submit PRs or create issues for any enhancements, bug fixes, or features you'd like to add.

License

This project is licensed under the Open Software License 3.0 (OSL-3.0).

Copyright (c) 2023 Cristian Magherusan-Stanciu, LeanerCloud.com.

Screenshots

*Elastic Network Interfaces (also include EC2, LBs amd EIPs)* | EC2 Instances (includes attached EIPs) | Load Balancers | EIPs not attached to instances
╔════════════════════════════════════════════════════════════════Elastic Network Interfaces with Public IPs════════════════════════════════════════════════════════════════╗
║┌─────────┬────────────┬─────────────────────┬────┐                                                                                                                       ║
║│Region   │Public IP   │ENI ID               │Cost│                                                                                                                       ║
║├─────────┼────────────┼─────────────────────┼────┤                                                                                                                       ║
║│us-east-1│123.45.67.89│eni-1234567890abcdef │3.65│                                                                                                                       ║
║├─────────┼────────────┼─────────────────────┼────┤                                                                                                                       ║
║│us-east-1│123.45.67.89│eni-1234567890abcdef │3.65│                                                                                                                       ║
║├─────────┼────────────┼─────────────────────┼────┤                                                                                                                       ║
║│us-east-1│123.45.67.89│eni-1234567890abcdef │3.65│                                                                                                                       ║
║├─────────┼────────────┼─────────────────────┼────┤                                                                                                                       ║
║│us-east-1│123.45.67.89│eni-1234567890abcdef │3.65│                                                                                                                       ║
║├─────────┼────────────┼─────────────────────┼────┤                                                                                                                       ║
║│us-east-1│123.45.67.89│eni-1234567890abcdef │3.65│                                                                                                                       ║
╚══════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════╝
--------------------------------
Public IPs attached to 34 Elastic Network Intefaces: $124.10
EC2: $25.55 for 7 instances
Load balancers: $83.95 for 23 load balancer IPs
and $18.25 for 3 Elastic IPs
Note: ENI costs also include those for EC2, LB and EIP. Still, unattached EIPs have an additional cost, so the total IPv4 cost isn't exactly the same as the ENI cost
--------------------------------
Use arrows to move around | Press ESC to exit

Elastic Network Interfaces (also include EC2, LBs amd EIPs) | *EC2 Instances (includes attached EIPs)* | Load Balancers | EIPs not attached to instances
╔════════════════════════════════════════════════════════════════════════════EC2 Instances costs═══════════════════════════════════════════════════════════════════════════╗
║┌─────────┬─────────────────────┬──────────────┬───────────────────┬──────────────┬─────────────────────┬────────────────────────┬────┐                                   ║
║│Region   │Name Tag             │Instance State│Instance ID        │Public IP     │VPC ID               │Subnet ID               │Cost│                                   ║
║├─────────┼─────────────────────┼──────────────┼───────────────────┼──────────────┼─────────────────────┼────────────────────────┼────┤                                   ║
║│us-east-1│Dev-Server           │running       │i-1234567890abcdef │123.45.67.89  │vpc-d5d4a0ac         │subnet-80f348ca         │3.65│                                   ║
║├─────────┼─────────────────────┼──────────────┼───────────────────┼──────────────┼─────────────────────┼────────────────────────┼────┤                                   ║
║│us-east-1│                     │running       │i-1234567890abcdef │123.45.67.89  │vpc-d5d4a0ac         │subnet-80f348ca         │3.65│                                   ║
║├─────────┼─────────────────────┼──────────────┼───────────────────┼──────────────┼─────────────────────┼────────────────────────┼────┤                                   ║
║│us-east-1│temp-db-load-instance│running       │i-1234567890abcdef │123.45.67.89  │vpc-0380ded1f8b84275f│subnet-05b3af0340538bbf5│3.65│                                   ║
║├─────────┼─────────────────────┼──────────────┼───────────────────┼──────────────┼─────────────────────┼────────────────────────┼────┤                                   ║
║│us-east-1│aws-nat              │running       │i-1234567890abcdef │123.45.67.89  │vpc-d5d4a0ac         │subnet-edad1fa7         │3.65│                                   ║
║├─────────┼─────────────────────┼──────────────┼───────────────────┼──────────────┼─────────────────────┼────────────────────────┼────┤                                   ║
║│us-east-1│test                 │stopped       │i-1234567890abcdef │123.45.67.89  │vpc-d5d4a0ac         │subnet-6191cb29         │3.65│                                   ║
╚══════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════╝

Elastic Network Interfaces (also include EC2, LBs amd EIPs) | EC2 Instances (includes attached EIPs) | *Load Balancers* | EIPs not attached to instances
╔════════════════════════════════════════════════════════════════════════════Load balancer costs═══════════════════════════════════════════════════════════════════════════╗
║┌─────────┬──────────────────┬───────────────────────────────────────────────────────────────────────┬────────┬─────────────────────────┬─────┐                           ║
║│Region   │Load Balancer Type│DNS Name                                                               │IP Count│Traffic MBs (last 7 days)│Cost │                           ║
║├─────────┼──────────────────┼───────────────────────────────────────────────────────────────────────┼────────┼─────────────────────────┼─────┤                           ║
║│us-east-1│application       | 1234567890abcdef.elb.us-east-1.amazonaws.com                          │3       │1.65                     │10.95│                           ║
║├─────────┼──────────────────┼───────────────────────────────────────────────────────────────────────┼────────┼─────────────────────────┼─────┤                           ║
║│us-east-1│network           │1234567890abcdef.elb.us-east-1.amazonaws.com                           │2       │0.00                     │7.30 │                           ║
║├─────────┼──────────────────┼───────────────────────────────────────────────────────────────────────┼────────┼─────────────────────────┼─────┤                           ║
║│us-east-1│application       │1234567890abcdef.elb.us-east-1.amazonaws.com                           │3       │1.20                     │10.95│                           ║
║├─────────┼──────────────────┼───────────────────────────────────────────────────────────────────────┼────────┼─────────────────────────┼─────┤                           ║
║│us-east-1│application       │1234567890abcdef.elb.us-east-1.amazonaws.com                           │2       │4.17                     │7.30 │                           ║
║├─────────┼──────────────────┼───────────────────────────────────────────────────────────────────────┼────────┼─────────────────────────┼─────┤                           ║
║│us-east-1│classic           │1234567890abcdef.elb.us-east-1.amazonaws.com                           │2       │166.95                   │7.30 │                           ║
╚══════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════╝
Elastic Network Interfaces (also include EC2, LBs amd EIPs) | EC2 Instances (includes attached EIPs) | Load Balancers | *EIPs not attached to instances*
╔════════════════════════════════════════════════════════════════════════════════Elastic IPs═══════════════════════════════════════════════════════════════════════════════╗
║┌─────────┬───────────────────────────┬─────────────┬──────────────────────────────────┬────┐                                                                             ║
║│Region   │Name tag                   │Public IP    │Attached Resource                 │Cost│                                                                             ║
║├─────────┼───────────────────────────┼─────────────┼──────────────────────────────────┼────┤                                                                             ║
║│us-east-1│                           │123.45.67.89 │                                  │7.30│                                                                             ║
║├─────────┼───────────────────────────┼─────────────┼──────────────────────────────────┼────┤                                                                             ║
║│us-east-1│                           │123.45.67.89 │                                  │7.30│                                                                             ║
║├─────────┼───────────────────────────┼─────────────┼──────────────────────────────────┼────┤                                                                             ║
║│us-east-1│nat-prod-vpc-us-east-1a    │123.45.67.89 │NAT Gateway: nat-1234567890abcdef │3.65│                                                                             ║
║└─────────┴───────────────────────────┴─────────────┴──────────────────────────────────┴────┘                                                                             ║
╚══════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════════╝
Credits
  • Erik Norman, for the idea and early feedback.
  • This project was largely written using ChatGPT GPT-4, as you can see in detail in these ChatGPT sessions: 1 2 3 4 5 6 7.

Documentation

Overview

* Copyright (C) 2023 Cristian Magherusan-Stanciu. All rights reserved. * * This program is free software: you can redistribute it and/or modify * it under the terms of the Open Software License version 3.0 as published * by the Open Source Initiative. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * Open Software License version 3.0 for more details. * * You should have received a copy of the Open Software License version 3.0 * along with this program. If not, see <https://opensource.org/licenses/OSL-3.0>.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL