Skip to content

annkuoQ/aws-cloudwatch-dashboard-generator-for-infrastructure-event-management

 
 

Repository files navigation

AWS CloudWatch Dashboard Generator For Infrastructure Event Management

License: MIT AWS Provider

The purpose of this Python based command line tool is to generate a CloudWatch Dashboard for monitoring AWS resources during IEM (AWS Infrastructure Event Management). The generated CloudWatch dashboard is based on the resources you provide and contains predefined useful CloudWatch metrics selected by AWS Support engineers for IEM scenarios.

What is AWS Infrastructure Event Management?

AWS Infrastructure Event Management (IEM) offers architecture and scaling guidance and operational support during the preparation and execution of planned events, such as shopping holidays, product launches, and migrations. For these events, AWS Infrastructure Event Management will help you assess operational readiness, identify and mitigate risks, and execute your event confidently with AWS experts by your side. The program is included in the Enterprise Support plan and is available to Business Support customers for an additional fee.

For more information about Infrastructure Event Management, please visit the official IEM website.

Currently Supported AWS Resource Types

Resource Types Supported?
Application Load Balancer
Classic Load Balancer
CloudFront
EC2
ElastiCache
Network Load Balancer
RDS
NAT Gateway
Aurora
Elastic Block Store Work in progress
EC2 Auto Scaling Groups Work in progress

Installation

Prerequisites

  • Python version 3.8

First install pip is the package installer for Python

$ python -m ensurepip --upgrade --user
If you have any issue to install pip, try using get-pip.py to install
1. Download the script, from https://bootstrap.pypa.io/get-pip.py.
2. Run get-pip.py
$ python get-pip.py

Troubleshooting

# If you run pip install but got error command not found: pip

It might indicated that your pip install path in not in env PATH, please reference WARNING message while install pip to find install path or try

$ /Users/${USER}/Library/Python/3.8/bin/pip install -r requirements.txt
Find more information at pip installation document: https://pip.pypa.io/en/stable/installation/

Install Dependencies

pip install -r requirements.txt

Then execute this tool.

$ python3 iemcwd.py -h
Usage: iemcwd.py [OPTIONS]

  IEMCWD is a tool to generate an IEM CloudWatch Dashboard based on
  resources you provide. The IEM CloudWatch Dashboard contains useful
  predefined metrics for IEM monitoring.

Options:
  -f, --file FILENAME         [required]
  -o, --output-file FILENAME  [required]
  -h, --help                  Show this message and exit.

Usage

The tool is quite simple. It reads a CSV file to get your resource IDs, then output the dashboard JSON to the directory you specified.

Using CSV file as an input

There is an example CSV file at inputs/csv/example.csv under this package for your reference. The table in CSV file must follow the format as below:

service region_code dim1_name dim1_value dim2_name dim2_value
CloudWatch Namespace region code DimensionName1 DimensionValue1 DimensionName2 DimensionValue2

For the explanation of these attributes, see below for more.

You may create a CSV file matching the columns and format above, or fill in inputs/csv/fill-in.csv with the resources you want to monitor on the dashboard. The order of entries(rows) in this table does not matter. The below is an example for the CSV input file, or refer to inputs/csv/example.csv in this repository. Though most of the service only requires one metric (dim1_name and dim1_value columns), please note that some services, including Elasticache, contain a second dimension entry dim2_name and dim2_value.

service region_code dim1_name dim1_value dim2_name dim2_value
ALB ap-northeast-1 LoadBalancer app/my-alb1/1234567890123456
NLB ap-northeast-1 LoadBalancer net/my-nlb1/1234567890123456
NAT ap-northeast-1 NatGatewayId nat-0abcdef1234567890
CloudFront us-east-1 DistributionId EDFDVBD6EXAMPLE
EC2 ap-northeast-1 InstanceId i-0abcdef1234567890
RDS ap-northeast-1 DBInstanceIdentifier support-instance-1
AuroraCluster ap-northeast-1 DBClusterIdentifier cluster-001
AuroraInstance ap-northeast-1 DBInstanceIdentifier instance-001
ElastiCache ap-northeast-1 CacheClusterId support-001 CacheNodeId 0001

Example:

python3 iemcwd.py -f inputs/csv/example.csv -o outputs/example_output.json

Successfully generated CloudWatch dashBoard JSON file.

After generating the dashboard JSON file, use the following AWS CLI command to create a CloudWatch based on this JSON file:

$ aws cloudwatch put-dashboard --dashboard-name your-iem-dashboard --dashboard-body file://outputs/example_output.json

You may also follow the below documentation to create the CloudWatch dashboard using AWS Console using the generated JSON:

Attribute explanation:

service should be one of the following:

  • ALB
  • CLB
  • CloudFront
  • EC2
  • ElastiCache
  • NLB
  • RDS
  • NAT
  • AuroraCluster

region_code is the AWS region where your resource is located at. See definitions/Regions.json for a list of region code.

dim1_name and dim1_value is the dimension of a metric in Cloud Watch. A dimension is a name/value pair that is part of the identity of a metric.Take EC2 for example, the dim1_name is InstanceId, and dim1_value will be the instance ID. Some metrics may contain multiple dimensions, such as ElastiCache. Understanding each AWS service resource Dimension here: https://docs.aws.amazon.com/AmazonCloudWatch/latest/monitoring/aws-services-cloudwatch-metrics.html

Security

See CONTRIBUTING for more information.

License

This library is licensed under the MIT-0 License. See the LICENSE file.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%