Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Terraform with existing production resources

I’m new to Terraform, I’d like to eventually have a Terraform template of my production resources so I can easily deploy to multi-regions and for disaster recovery. How can I do this if my resources on AWS (EC2, S3,VPC, etc) are already deployed?

like image 935
J. Thomas Avatar asked Dec 27 '17 18:12

J. Thomas


People also ask

Can terraform manage existing resources?

Terraform is able to import existing infrastructure. This allows you take resources you've created by some other means and bring it under Terraform management.

Can terraform update an existing resource?

In addition to creating new resources, Terraform can modify existing resources. Open your main.tf file.


3 Answers

You can use terraform import feature for this. Here is a link to the documentation : https://www.terraform.io/docs/import/index.html

However it's not capable of generating configurations for you. You have to build up the configurations and import the state of resources.

The current implementation of Terraform import can only import resources into the state. It does not generate configuration. A future version of Terraform will also generate configuration.

You can do it incrementally, start writing configurations for resources one by one.

Ex:

  1. Write configurations for VPC.
  2. Import VPC state
  3. Write configs for EC2 instance.
  4. Import EC2 state

After successfully importing a resource/s. You can use terraform plan command to ensure the state is correctly matching.

Remember to make use of the terraform modules (https://www.terraform.io/docs/modules/create.html) to better structure the code so that you could reuse them with other regions and environments.

Here's an article which describes a way to use terraform with multi-region deployments. https://medium.com/@ctindel/multi-region-aws-app-deployments-with-terraform-modules-859c9ecb64f4

like image 130
Anuruddha Avatar answered Oct 02 '22 20:10

Anuruddha


Google has an opensource tool called terraformer for reverse Terraforming an existing AWS stack into tf and tfstate files.

They also support GCP (obviously), K8s, Openstack and other platforms.

AWS example usage:

terraformer import aws --resources=vpc,subnet --connect=true --regions=eu-west-1 --profile=prod

terraformer import aws --resources=vpc,subnet --filter=aws_vpc=vpc_id1:vpc_id2:vpc_id3 --regions=eu-west-1
like image 27
Dylan Hogg Avatar answered Oct 02 '22 20:10

Dylan Hogg


I think you should try considering "Terraforming" in this case. It will export your current aws infrastructure in terraform style.

Ref: http://terraforming.dtan4.net/

Github: https://github.com/dtan4/terraforming

You may also consider using segment stack of production-ready modules of terraform, which you can use as the way you want to.

https://github.com/segmentio/stack

like image 45
mohit Avatar answered Oct 02 '22 18:10

mohit