2016-05-18 13:56:51 -05:00
|
|
|
---
|
|
|
|
layout: "docs"
|
|
|
|
page_title: "Command: import"
|
|
|
|
sidebar_current: "docs-commands-import"
|
|
|
|
description: |-
|
|
|
|
The `terraform import` command is used to import existing resources into Terraform.
|
|
|
|
---
|
|
|
|
|
|
|
|
# Command: import
|
|
|
|
|
|
|
|
The `terraform import` command is used to
|
|
|
|
[import existing resources](/docs/import/index.html)
|
|
|
|
into Terraform.
|
|
|
|
|
|
|
|
## Usage
|
|
|
|
|
|
|
|
Usage: `terraform import [options] ADDRESS ID`
|
|
|
|
|
|
|
|
Import will find the existing resource from ID and import it into your Terraform
|
|
|
|
state at the given ADDRESS.
|
|
|
|
|
|
|
|
ADDRESS must be a valid [resource address](/docs/internals/resource-addressing.html).
|
|
|
|
Because any resource address is valid, the import command can import resources
|
2016-08-15 18:10:41 -05:00
|
|
|
into modules as well directly into the root of your state.
|
2016-05-18 13:56:51 -05:00
|
|
|
|
|
|
|
ID is dependent on the resource type being imported. For example, for AWS
|
|
|
|
instances it is the instance ID (`i-abcd1234`) but for AWS Route53 zones
|
2016-10-09 11:29:38 -05:00
|
|
|
it is the zone ID (`Z12ABC4UGMOZ2N`). Please reference the provider documentation for details
|
2016-05-18 13:56:51 -05:00
|
|
|
on the ID format. If you're unsure, feel free to just try an ID. If the ID
|
|
|
|
is invalid, you'll just receive an error message.
|
|
|
|
|
|
|
|
The command-line flags are all optional. The list of available flags are:
|
|
|
|
|
|
|
|
* `-backup=path` - Path to backup the existing state file. Defaults to
|
|
|
|
the `-state-out` path with the ".backup" extension. Set to "-" to disable
|
|
|
|
backups.
|
|
|
|
|
2016-11-02 13:11:42 -05:00
|
|
|
* `-config=path` - Path to directory of Terraform configuration files that
|
|
|
|
configure the provider for import. This defaults to your working directory.
|
|
|
|
If this directory contains no Terraform configuration files, the provider
|
|
|
|
must be configured via manual input or environmental variables.
|
|
|
|
|
2016-05-18 13:56:51 -05:00
|
|
|
* `-input=true` - Whether to ask for input for provider configuration.
|
|
|
|
|
2017-04-04 12:48:59 -05:00
|
|
|
* `-lock=true` - Lock the state file when locking is supported.
|
2016-05-18 13:56:51 -05:00
|
|
|
|
2017-04-04 12:48:59 -05:00
|
|
|
* `-lock-timeout=0s` - Duration to retry a state lock.
|
|
|
|
|
|
|
|
* `-no-color` - If specified, output won't contain any color.
|
2016-05-18 13:56:51 -05:00
|
|
|
|
2019-03-06 08:25:36 -06:00
|
|
|
* `-parallelism=n` - Limit the number of concurrent operation as Terraform
|
|
|
|
[walks the graph](/docs/internals/graph.html#walking-the-graph). Defaults
|
|
|
|
to 10.
|
|
|
|
|
2017-06-02 14:21:09 -05:00
|
|
|
* `-provider=provider` - Specified provider to use for import. The value should be a provider
|
|
|
|
alias in the form `TYPE.ALIAS`, such as "aws.eu". This defaults to the normal
|
2016-11-23 11:40:11 -06:00
|
|
|
provider based on the prefix of the resource being imported. You usually
|
|
|
|
don't need to specify this.
|
2016-11-23 03:44:52 -06:00
|
|
|
|
2017-08-09 13:01:45 -05:00
|
|
|
* `-state=path` - Path to the source state file to read from. Defaults to the
|
|
|
|
configured backend, or "terraform.tfstate".
|
2017-04-04 12:48:59 -05:00
|
|
|
|
2017-08-09 13:01:45 -05:00
|
|
|
* `-state-out=path` - Path to the destination state file to write to. If this
|
|
|
|
isn't specified the source state file will be used. This can be a new or
|
|
|
|
existing path.
|
2017-04-04 12:48:59 -05:00
|
|
|
|
2017-01-24 15:01:23 -06:00
|
|
|
* `-var 'foo=bar'` - Set a variable in the Terraform configuration. This flag
|
|
|
|
can be set multiple times. Variable values are interpreted as
|
|
|
|
[HCL](/docs/configuration/syntax.html#HCL), so list and map values can be
|
|
|
|
specified via this flag. This is only useful with the `-config` flag.
|
|
|
|
|
|
|
|
* `-var-file=foo` - Set variables in the Terraform configuration from
|
2017-06-21 20:22:07 -05:00
|
|
|
a [variable file](/docs/configuration/variables.html#variable-files). If
|
|
|
|
a `terraform.tfvars` or any `.auto.tfvars` files are present in the current
|
|
|
|
directory, they will be automatically loaded. `terraform.tfvars` is loaded
|
|
|
|
first and the `.auto.tfvars` files after in alphabetical order. Any files
|
|
|
|
specified by `-var-file` override any values set automatically from files in
|
|
|
|
the working directory. This flag can be used multiple times. This is only
|
|
|
|
useful with the `-config` flag.
|
2017-01-24 15:01:23 -06:00
|
|
|
|
2016-05-18 13:56:51 -05:00
|
|
|
## Provider Configuration
|
|
|
|
|
2016-11-02 13:11:42 -05:00
|
|
|
Terraform will attempt to load configuration files that configure the
|
|
|
|
provider being used for import. If no configuration files are present or
|
|
|
|
no configuration for that specific provider is present, Terraform will
|
|
|
|
prompt you for access credentials. You may also specify environmental variables
|
|
|
|
to configure the provider.
|
|
|
|
|
|
|
|
The only limitation Terraform has when reading the configuration files
|
|
|
|
is that the import provider configurations must not depend on non-variable
|
|
|
|
inputs. For example, a provider configuration cannot depend on a data
|
|
|
|
source.
|
|
|
|
|
|
|
|
As a working example, if you're importing AWS resources and you have a
|
|
|
|
configuration file with the contents below, then Terraform will configure
|
|
|
|
the AWS provider with this file.
|
|
|
|
|
2017-04-05 10:29:27 -05:00
|
|
|
```hcl
|
2016-11-02 13:11:42 -05:00
|
|
|
variable "access_key" {}
|
|
|
|
variable "secret_key" {}
|
|
|
|
|
|
|
|
provider "aws" {
|
|
|
|
access_key = "${var.access_key}"
|
|
|
|
secret_key = "${var.secret_key}"
|
|
|
|
}
|
|
|
|
```
|
2016-05-18 13:56:51 -05:00
|
|
|
|
2019-08-02 18:36:24 -05:00
|
|
|
## Example: Import into Resource
|
2016-05-18 13:56:51 -05:00
|
|
|
|
2019-08-02 18:36:24 -05:00
|
|
|
This example will import an AWS instance into the `aws_instance` resource named `foo`:
|
2016-05-18 13:56:51 -05:00
|
|
|
|
2017-04-05 10:29:27 -05:00
|
|
|
```shell
|
2016-05-18 13:56:51 -05:00
|
|
|
$ terraform import aws_instance.foo i-abcd1234
|
|
|
|
```
|
|
|
|
|
2019-08-02 18:36:24 -05:00
|
|
|
## Example: Import into Module
|
2016-05-18 13:56:51 -05:00
|
|
|
|
2019-08-02 18:36:24 -05:00
|
|
|
The example below will import an AWS instance into the `aws_instance` resource named `bar` into a module named `foo`:
|
2016-05-18 13:56:51 -05:00
|
|
|
|
2017-04-05 10:29:27 -05:00
|
|
|
```shell
|
2016-05-18 13:56:51 -05:00
|
|
|
$ terraform import module.foo.aws_instance.bar i-abcd1234
|
|
|
|
```
|
2019-08-02 18:36:24 -05:00
|
|
|
|
2019-08-05 20:50:17 -05:00
|
|
|
## Example: Import into Resource configured with count
|
2019-08-02 18:36:24 -05:00
|
|
|
|
2019-08-05 20:50:17 -05:00
|
|
|
The example below will import an AWS instance into the first instance of the `aws_instance` resource named `baz` configured with
|
2019-08-02 18:36:24 -05:00
|
|
|
[`count`](/docs/configuration/resources.html#count-multiple-resource-instances-by-count):
|
|
|
|
|
|
|
|
```shell
|
|
|
|
$ terraform import 'aws_instance.baz[0]' i-abcd1234
|
|
|
|
```
|
|
|
|
|
2019-08-05 20:50:17 -05:00
|
|
|
## Example: Import into Resource configured with for_each
|
2019-08-02 18:36:24 -05:00
|
|
|
|
2019-08-05 20:50:17 -05:00
|
|
|
The example below will import an AWS instance into the `"example"` instance of the `aws_instance` resource named `baz` configured with
|
2019-08-02 18:36:24 -05:00
|
|
|
[`for_each`](/docs/configuration/resources.html#for_each-multiple-resource-instances-defined-by-a-map-or-set-of-strings):
|
|
|
|
|
|
|
|
Linux, Mac OS, and UNIX:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
$ terraform import 'aws_instance.baz["example"]' i-abcd1234
|
|
|
|
```
|
|
|
|
|
|
|
|
PowerShell:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
$ terraform import 'aws_instance.baz[\"example\"]' i-abcd1234
|
|
|
|
```
|
|
|
|
|
|
|
|
Windows `cmd.exe`:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
$ terraform import aws_instance.baz[\"example\"] i-abcd1234
|
|
|
|
```
|