Terraform Import is a powerful feature that allows you to bring existing infrastructure—created manually or by other tools—into your Terraform-managed ecosystem. Whether you’re transitioning from a manual setup or consolidating tools in your DevOps workflow, understanding how to use terraform import is essential.
This tutorial walks you through the process of importing unmanaged infrastructure into Terraform, so you can achieve full infrastructure-as-code (IaC) control.
Table of Contents
Why Terraform Import Is Important
In an ideal scenario, all resources in your environment would be managed using Terraform. This ensures consistency, version control, and reproducibility.
However, in real-world use cases, some resources might already exist—provisioned manually via the AWS Console or created by tools like Ansible or CloudFormation. Terraform won’t know about these unless explicitly told.
This is where Terraform Import becomes useful. It allows you to register existing infrastructure in Terraform’s state file and manage it going forward using standard Terraform commands like plan, apply, and destroy.
Understanding Terraform Import Basics
Terraform tracks the resources it manages in a state file, which is essential for understanding what already exists and what needs to be changed. When a resource is imported, it is added to this state file.
Syntax for Importing a Resource
The syntax for using the Terraform import command is:
terraform import <resource_type>.<resource_name> <resource_id>
For example, if you want to import an AWS EC2 instance with ID i-1234567890abcdef, and your resource block is called aws_instance.webserver, you’d run:
terraform import aws_instance.webserver i-1234567890abcdefStep-by-Step: How Terraform Import Works
1. Identify the Resource
First, determine which existing resource you want to import. For AWS resources, you can find this in the AWS Management Console. Copy the unique identifier, such as an instance ID for EC2.
2. Write an Empty Resource Block
Before running the import command, you need a matching resource block in your Terraform configuration, even if it’s initially empty:
resource "aws_instance" "webserver" {}
Terraform won’t automatically generate this block, so you must write it manually. You can flesh it out later once the resource is imported.
3. Run the Import Command
Now execute the import command using the correct syntax:
terraform import aws_instance.webserver i-1234567890abcdef
This updates the state file to reflect that Terraform now manages this resource.
4. Complete the Resource Block
After importing, you need to manually populate the configuration block with the correct attributes. You can get these values in two ways:
- From the cloud provider console (e.g., AWS EC2 instance details).
- By inspecting the Terraform state file.
A filled resource block might look like this:
resource "aws_instance" "webserver" {
  ami           = "ami-0abcd1234ef567890"
  instance_type = "t2.micro"
  key_name      = "web-key"
  vpc_security_group_ids = ["sg-0abc12345def6789"]
}5. Run terraform plan
After completing the resource definition, run:
terraform plan
Terraform will confirm that the resource already exists and that no changes are needed. This step ensures your configuration is synchronized with the infrastructure.
6. Manage Resource Normally
Once imported, the resource behaves like any other Terraform-managed resource. You can now:
- Update it using configuration changes.
- Destroy it using terraform destroy.
- Reuse it in modules or workflows.
Key Considerations When Using Terraform Import
Terraform Does Not Create Code
The import operation only updates the state—not your configuration files. Always manually add and complete the corresponding resource block.
Version Compatibility
Terraform import has matured over time. Ensure your Terraform version is up to date for improved import stability and expanded provider support.
Use With Caution
Importing resources incorrectly or without matching configuration can lead to state mismatches. Always review your state file and configuration carefully after importing.
Best Practices for Terraform Import
- Always back up your Terraform state before running import.
- Use descriptive resource names to avoid confusion in your configuration.
- Document imported resources clearly in code comments.
- Validate your configuration using terraform validateafter import.
Conclusion
Terraform Import is a critical tool for DevOps engineers and infrastructure teams managing hybrid environments. Whether you’re transitioning from manual setups or integrating legacy resources, this feature allows you to unify your infrastructure under a single IaC framework.
By following the right process—defining empty blocks, executing imports correctly, and completing configurations—you ensure that all your resources become Terraform-native, enabling more consistent and automated deployments moving forward.
Frequently Asked Questions (FAQ)
1. What does Terraform Import do?
Terraform Import links existing infrastructure to your Terraform state so that you can manage it with Terraform.
2. Does Terraform Import create resources?
No. It only maps existing infrastructure into the state file. It does not create or modify resources during import.
3. Can I import resources without a resource block?
No. You must define at least an empty resource block in your configuration before running the import.
4. Does Terraform auto-generate configuration during import?
No. You must manually define and populate the configuration block for imported resources.
5. Can imported resources be destroyed by Terraform?
Yes. Once imported and fully configured, you can manage the resource lifecycle—including destruction—via Terraform.