Harnessing Infrastructure as Code (IaC Generator) with AWS CloudFormation: Automating Previously Manual Resources
Introduction:
Do you ever feel like you’re spending more time manually configuring AWS resources than building your actual applications? If you’ve got a collection of AWS resources that you created by hand, you’re not alone. But there’s a better way! This guide will show you how to leverage the power of Infrastructure as Code (IaC) with AWS CloudFormation to automate the management of your existing resources, saving you time and headaches. We’ll explore the benefits of IaC, how CloudFormation works, and the steps to bring your manually created resources under the control of this powerful tool. Get ready to streamline your workflow and unleash the magic of IaC with CloudFormation!
What is Aws Cloudformation:
AWS CloudFormation is an infrastructure automation service that lets you define and deploy your AWS resources using code templates. Instead of manually provisioning and configuring each resource, you write a template that describes your infrastructure. CloudFormation then takes care of creating and managing all the resources you specify, ensuring consistency and repeatability. This frees you up from tedious tasks and lets you focus on building your applications.
Challenges we are facing in the Cloud:
The cloud’s allure is undeniable, but maximizing its benefits requires a shift in mindset. While cost, time, and recovery objectives (RTO/RPO) are crucial, many overlook the hidden time-suck and risk of manual infrastructure provisioning and management. This manual approach not only drives up costs but also introduces inconsistencies and potential errors.
This highlights a critical gap — optimizing team efficiency within the cloud environment.
Solution:
This is where Infrastructure as Code (IaC) comes in. By automating infrastructure management through IaC, we can unleash a new level of efficiency, freeing teams to focus on higher-value activities and innovation.
IAC Generator:
The IaC generator in AWS CloudFormation is a time-saving tool that helps you bring existing, manually created resources under IaC management. It scans your account, identifies your resources, and generates a CloudFormation template that represents them. This template becomes the code for provisioning and managing those resources.
Think of it like creating a blueprint of your existing infrastructure. The IaC generator automates the blueprint creation, saving you the effort of writing the template by hand. While some manual adjustments might be needed, it provides a solid foundation for IaC with CloudFormation.
Excited? Let Deep Dive into the HandsOn
Environment Details:
- We have an existing Aws Account.
- A VPC is manually Created.
Generating and using a template
This section describes how to create a template, add resources to your template, and import resources from the template into a stack using the IaC generator feature.
To open a new template using the IaC generator
- Sign in to the AWS Management Console and open the AWS CloudFormation console at https://console.aws.amazon.com/cloudformation.
- From the navigation pane, choose IaC generator.
data:image/s3,"s3://crabby-images/69ad8/69ad8e851f71230c60d402942eb83317d818c1d0" alt=""
3. From the Scans panel, choose Start a new scan. Scans discover the resources provisioned in your account and the relationship between resources. The more resources you have in your account in the Region, the longer the scan takes.
data:image/s3,"s3://crabby-images/41be5/41be59e04b48a1777c79bfa08749386af59a2bde" alt=""
data:image/s3,"s3://crabby-images/91a83/91a836235755ed9e640c269a24b38bfc027733fa" alt=""
4. From the Templates panel, choose Create template.
data:image/s3,"s3://crabby-images/ad98d/ad98d509a687b1a7a5c139564ccb00a18ecff6eb" alt=""
data:image/s3,"s3://crabby-images/41e5d/41e5dccb29936cd432f65deff77fc9beb48fc500" alt=""
- Select Start from a new template.
- In the Template name panel, enter a name for your generated template.
- (Optional) Configure your Deletion policy and Update replace policy.
- Choose Next to add scanned resources to the template.
To add scanned resources to your template
- From the list of scanned resources, browse the list of scanned resources. You can filter the resources by resource identifier, resource type, or tags. The filters are mutually inclusive.
- Select the resource or resources you want to add.
- Repeat Steps 1 and 2, until you’ve added all needed resources to your template.
data:image/s3,"s3://crabby-images/a22b7/a22b70f6956f8123a21e56f3c8382d9910a77387" alt=""
data:image/s3,"s3://crabby-images/a22b7/a22b70f6956f8123a21e56f3c8382d9910a77387" alt=""
5. Choose Next to exit the Add scanned resources page and proceed to the Add related resources page.
data:image/s3,"s3://crabby-images/a1f66/a1f66eecde0839348eace05c50b3d69d4c3a3e7d" alt=""
data:image/s3,"s3://crabby-images/0f375/0f375f7ff33008aa826c9907f348df3b4a53e0f6" alt=""
data:image/s3,"s3://crabby-images/a2708/a2708f0fab5a70eb9d65859796c4fa64531b8c31" alt=""
6. Review a recommended list of related resources. Related resources, such as Amazon EC2 instances and security groups, are interdependent and typically belong to the same workload. Select the related resources that you want to include in the generated template.
7. Review the template details, scanned resources, and related resources. Choose Edit to make any changes.
data:image/s3,"s3://crabby-images/5810f/5810f3c0e40bc384fe0a9b5ddd9bb99c8d488b0b" alt=""
8. Choose to Create a template to exit the Review and create a page and create the template.
data:image/s3,"s3://crabby-images/f7216/f7216e28039ea513c9f75c03066a37ee1fc88eb6" alt=""
9. Wait for the Cloudformation template to be created via IAC generator.
data:image/s3,"s3://crabby-images/b0c9b/b0c9b3c26bfa5ed3c6ce05f6df3713b3092b6bc1" alt=""
10. Review the Cloudfromation Template Definition and Template Resources from the console.
data:image/s3,"s3://crabby-images/fc9f7/fc9f7273527f22617d544d5ca7b4e3f8549ace09" alt=""
data:image/s3,"s3://crabby-images/9d4ab/9d4ab334391474182ff5b2132cc06e1d8c7377ec" alt=""
11. Download the Cloud formation template and make changes if required.
data:image/s3,"s3://crabby-images/087ba/087baeba1ade0b830aed1c822e9c1fb7014b7446" alt=""
12. Import the Template. Click on the import to stack option and provide the details as described below
data:image/s3,"s3://crabby-images/b36f8/b36f8c6143a91b5f03f02bc09c7634f1b1d25e7f" alt=""
data:image/s3,"s3://crabby-images/cef92/cef92c1e39bdfabb94d5a9ac0debd6ba720fe664" alt=""
data:image/s3,"s3://crabby-images/777d0/777d0bf890dd44d1bc27a5e438b76eb68c315885" alt=""
data:image/s3,"s3://crabby-images/7a162/7a162022656761b375c47fe2ce0e14590b75d1a5" alt=""
data:image/s3,"s3://crabby-images/2d5f4/2d5f48b5867122e7ec1f9923618390d377396c37" alt=""
data:image/s3,"s3://crabby-images/7be03/7be0301ac67e00c894a0b0cafd9779a91c79a86f" alt=""
data:image/s3,"s3://crabby-images/8ba15/8ba15e059be2dcce37ee3b4860395b8836078307" alt=""
data:image/s3,"s3://crabby-images/e8a65/e8a65768d2c07324b01b3b6b9962ae88492b884f" alt=""
Conclusion:
With the successful import of your entire networking stack, it’s time to level up your infrastructure management! For enhanced collaboration and future updates, consider storing this CloudFormation template in a version control system like Git.Remember, to prevent configuration drift (where the actual state differs from the defined configuration), always make changes through CloudFormation going forward.
Documentation Links: