ec2_resource_graph
What it does
Traverses resource associations based on an EC2 tag. Puts output into JSON file in S3 (for use by Glue/Athena). Currently includes EC2 instances, EBS volumes, snapshots, and ALB/NLB, EIP, Classic LB.
Pre-requisits
AWS API and SAM CLI installed Note: AWS Cloud9 on Amazon Linux2 was used in development, or AWS CloudShell. These come pre-installed.
Deployment
- Clone this repository from github.
$ git clone https://github.com/AndyShortt/this_repo_name.git
$ cd ec2_resource_graph/
- Run SAM build command.
$ sam build
- Run SAM deploy. Name stack and accept defaults or enter Y on other inputs.
$ sam deploy --guided --capabilities CAPABILITY_NAMED_IAM
-
Log into AWS CloudFormation, deploy new StackSet to accounts you will include in resource discovery. Only region required is us-east-1 since IAM is global. Use the template named "ResourceDiscoveryLambda.yaml" in the root directory as your Cloudformation templated for the StackSet, make sure to click the checkbox on the "Review" screen to allow it to created named IAM resources.
-
Update parameters in params.json to reflect the EC2 tags, accounts, regions, and output bucket for S3 files.
-
Find the "lambaController" lambda function that SAM created in the lambda console. Note the name. Invoke lambda
$ aws lambda invoke --function-name your-app-lambdaController-123 --payload file://params.json out.txt
- Check s3 bucket for output