Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/imsalmanmalik/aws-resource-governance-cloudwatch-lambda
AWS Cloud Watch in combination with AWS Lambda to govern the resources and make sure it is in compliance with the organisational policies.
https://github.com/imsalmanmalik/aws-resource-governance-cloudwatch-lambda
aws-ec2 boto3 cloudwatch iam-role-policy lambda-functions python3
Last synced: about 2 months ago
JSON representation
AWS Cloud Watch in combination with AWS Lambda to govern the resources and make sure it is in compliance with the organisational policies.
- Host: GitHub
- URL: https://github.com/imsalmanmalik/aws-resource-governance-cloudwatch-lambda
- Owner: imsalmanmalik
- Created: 2023-08-02T09:17:35.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2023-08-02T10:40:07.000Z (over 1 year ago)
- Last Synced: 2023-08-02T11:47:59.811Z (over 1 year ago)
- Topics: aws-ec2, boto3, cloudwatch, iam-role-policy, lambda-functions, python3
- Language: Python
- Homepage: https://boto3.amazonaws.com/v1/documentation/api/latest/reference/services/ec2.html
- Size: 1.06 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
## Overview
The Lambda function is designed to be triggered by CloudWatch Events for EC2 volume modifications and EBS snapshot creations.
In this function, we first check if the resource ARN in the event data is for a volume or a snapshot.
1. If it's a volume, the function modifies the volume, creates a snapshot, and adds the tag to the snapshot.
2. If it's a snapshot, the function adds the tag to the snapshot directly.This function would work for both volume modification events and snapshot creation events.
## High Level Design
![55D21237-CECD-47D1-95EB-E5C97F84758D_1_201_a](https://github.com/imsalmanmalik/AWS-Resource-Governance-CloudWatch-Lambda/assets/121328365/9fa75fdf-3066-4081-92d3-ade6912d4c8d)
## Project Scope
- Unsecure S3 buckets: Lambda functions can be used to monitor S3 bucket access and enforce security policies, such as preventing public access, encrypting data at rest, and logging all access activity.
- No optimization of EC2 instances: Lambda functions can be used to monitor CPU utilization and other metrics of your EC2 instances, and automatically adjust the instance size or capacity based on the workload. This can help optimize performance and reduce costs.
- No automation of backups and disaster recovery: Lambda functions can be used to schedule backups and automate disaster recovery processes, such as copying data to a backup S3 bucket or launching a new EC2 instance in case of a failure.
- No automation of routine tasks: Lambda functions can be used to automate routine tasks, such as database backups, log analysis, and file processing. This can help reduce manual effort and improve efficiency.
- IAM permissions and roles: Lambda functions can be used to enforce IAM policies and roles, such as granting least privilege access and rotating access keys. This can help improve security and compliance.
# Getting Started
## Prerequisites
- AWS account with access to EC2, Lambda, and CloudWatch Services
- AWS CLI installed and configured
- Python 3.6 or higher
- An EC2 volume to perform operations on
## Deploying the Lambda Function- Clone this repository to your local machine.
- Navigate to the AWS Lambda console and create a new function.
- In the function code section, upload the code from this repository.
- Make sure your Lambda function has the necessary IAM permissions. It should have access to `ec2:ModifyVolume`, `ec2:CreateSnapshot`, and `ec2:CreateTags` actions.
- In the function triggers section, set up a new CloudWatch Event trigger. The event pattern should match EBS volume modification events and EBS snapshot creation events.
- Save your function.
## Testing the FunctionYou can test the function by manually changing the size or type of your EC2 volume, or creating a snapshot. Check the CloudWatch Logs for your function to verify that it's working as expected.
## Screenshots
1. This screenshot shows the CloudWatch log groups for the invoking Lambda function and helps in debugging and monitoring. Could also assist in understanding how 'event' is being parsed onto the Lambda function as a json payload. You can do this by adding `print(event)` at the top of your handler function and checking the logs after the function is triggered. Once you know the structure of the event object, you can adjust your function code accordingly.
2. This screenshot shows the Lambda console which shows an `EventBridge` between the Lambda function named as `resource_governance` and CloudWatch.
3. This screenshot shows the EBS console which displays how the invoking Lambda function adds a `Tag Key` and `Tag Value` to a newly created snapshot.