-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
2 changed files
with
100 additions
and
10 deletions.
There are no files selected for viewing
100 changes: 100 additions & 0 deletions
100
content/blog/wiping-your-aws-account-with-aws-nuke-and-gitlab-ci.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,100 @@ | ||
--- | ||
title: "Wiping your AWS account with AWS Nuke and Gitlab CI" | ||
date: 2023-07-10T21:54:55+01:00 | ||
draft: true | ||
language: en | ||
--- | ||
|
||
Wiping, cleaning up your AWS account, sounds a very dangerous, destructive action, and it indeed is. Specially when one tell you this can be performed automatically and on a schedule. Problems arise even if you don't touch your infrastructure, so why would one destroy it from time to time and on purpose? | ||
|
||
<!--more--> | ||
|
||
## Why? | ||
|
||
Well, there are some valid use cases for such tooling. **Hopefully none of these on live, production, user facing environments**. For example: | ||
- You have a personal, development, cloud account and you don't want to get an expensive cloud bill from AWS when you just want to test things out | ||
- You run tests for IaC which requires you to create resources and destroy them, often times leaving dangling resources behind | ||
- You have a team where each member has its own AWS account where they can do --- virtually --- anything, but like on the first use case, you don't want an expensive bill when people are just developing and testing things out! | ||
|
||
In such scenarios those accounts only host resources which are not intended to be used by the public. Whether this public are application users, developers, or anyone aside the person who create those resources and potentially her/his peers to whom she/he is showcasing things to. Also these very resources are better off being temporary, as they have a very short life-span: you create resources, confirm they work as you expect, then destroy them --- but often times you forget it. | ||
|
||
These use-cases are addressed by [aws-nuke](https://github.com/rebuy-de/aws-nuke). It destroys all your AWS resources on the specified accounts. _I discovered it when looking for something similar after forgetting an EKS cluster running for a week on my personal AWS account_ 😅, which didn't cost me more than $50.00 as far as I remember but it's useful to save money when possible and to avoid unnecessary costs, specially when next time I might not be so lucky. | ||
|
||
AWS Nuke can be run on number of ways. One of those is to run it on a CI pipeline. This is the approach I choose and discuss on the next sections. I implemented it using GitLab CI for daily destroying all of my personal AWS account resources. | ||
|
||
## Configuring aws-nuke | ||
|
||
The following snippet shows my configuration --- Account ID and user name omitted. | ||
|
||
```yaml | ||
regions: | ||
- eu-north-1 | ||
- ap-south-1 | ||
- eu-west-3 | ||
- eu-west-2 | ||
- eu-west-1 | ||
- ap-northeast-3 | ||
- ap-northeast-2 | ||
- ap-northeast-1 | ||
- sa-east-1 | ||
- ca-central-1 | ||
- ap-southeast-1 | ||
- ap-southeast-2 | ||
- eu-central-1 | ||
- us-east-1 | ||
- us-east-2 | ||
- us-west-1 | ||
- us-west-2 | ||
- global | ||
|
||
resource-types: | ||
excludes: | ||
- EC2DefaultSecurityGroupRule | ||
|
||
accounts: | ||
"<my-account-id>": | ||
filters: | ||
IAMUser: | ||
- "<my-user-name>" | ||
IAMUserPolicyAttachment: | ||
- "<my-user-name> -> AdministratorAccess" | ||
IAMVirtualMFADevice: | ||
- "arn:aws:iam::<my-account-id>:mfa/<my-user-name>" | ||
IAMUserGroupAttachment: | ||
- "<my-user-name> -> Admin" | ||
IAMLoginProfile: | ||
- "<my-user-name>" | ||
IAMGroup: | ||
- "Admin" | ||
IAMGroupPolicyAttachment: | ||
- "Admin -> AdministratorAccess" | ||
IAMUserAccessKey: | ||
- "<my-user-name> -> {{AWS_ACCESS_KEY_ID}}" | ||
EC2KeyPair: | ||
- "<key-pair-name-to-keep>" | ||
EC2Subnet: | ||
- property: DefaultVPC | ||
value: "true" | ||
EC2DHCPOption: | ||
- property: DefaultVPC | ||
value: "true" | ||
EC2InternetGateway: | ||
- property: DefaultVPC | ||
value: "true" | ||
EC2RouteTable: | ||
- property: DefaultVPC | ||
value: "true" | ||
EC2InternetGatewayAttachment: | ||
- property: DefaultVPC | ||
value: "true" | ||
EC2VPC: | ||
- property: IsDefault | ||
value: "true" | ||
CloudWatchDashboard: | ||
- "Main" | ||
|
||
``` | ||
|
||
Let's dig a bit into it: | ||
- First, I declare all the regions I want to wipe out, in my case these are all the AWS `regions` plus global --- for global resources like IAM users. | ||
- Second, I exclude from the destroy the AWS default security groups --- they're saved from the aws-nuke blast radius. |
This file was deleted.
Oops, something went wrong.