5

我正在使用 Terraform v1.0.0 并使用 AWS S3 和 AWS DynamoDB 创建了一个远程后端,正如 Yevgeniy Brikman 在Terraform Up & Running中解释的那样:

  1. 我为 S3 存储桶和 DynamoDB 表编写了代码,并通过terraform apply
  2. 我添加terraform { backend "S3" {} }到我的代码中
  3. 我创建了一个backend.hcl包含所有相关参数的文件
  4. 我通过调用将我的本地状态移动到 S3terraform init -backend-config=backend.hcl

现在我想将远程状态转换回本地状态,这样我就可以安全地删除远程后端。Brikman 解释说,要做到这一点,必须删除backend配置并调用terraform init. 当我尝试这个时,我看到了这个:

$ terraform init
Initializing modules...

Initializing the backend...
╷
│ Error: Backend configuration changed
│ 
│ A change in the backend configuration has been detected, which may require migrating existing state.
│ 
│ If you wish to attempt automatic migration of the state, use "terraform init -migrate-state".
│ If you wish to store the current configuration with no changes to the state, use "terraform init -reconfigure".
╵

我认为正确的方法是使用-reconfigure乍一看似乎有效的方法:

$ terraform init -reconfigure
Initializing modules...

Initializing the backend...

Initializing provider plugins...
- Reusing previous version of hashicorp/random from the dependency lock file
- Reusing previous version of hashicorp/aws from the dependency lock file
- Using previously-installed hashicorp/aws v3.47.0
- Using previously-installed hashicorp/random v3.1.0

Terraform has been successfully initialized!

但是,执行terraform plan显示初始化没有成功:

$ terraform plan
╷
│ Error: Backend initialization required, please run "terraform init"
│
│ Reason: Unsetting the previously set backend "s3"
│
│ The "backend" is the interface that Terraform uses to store state,
│ perform operations, etc. If this message is showing up, it means that the
│ Terraform configuration you're using is using a custom configuration for
│ the Terraform backend.
│
│ Changes to backend configurations require reinitialization. This allows
│ Terraform to set up the new configuration, copy existing state, etc. Please run
│ "terraform init" with either the "-reconfigure" or "-migrate-state" flags to
│ use the current configuration.
│
│ If the change reason above is incorrect, please verify your configuration
│ hasn't changed and try again. At this point, no changes to your existing
│ configuration or state have been made.
╵

取消设置后端的唯一方法似乎是通过terraform init -migrate-state

$ terraform init -migrate-state
Initializing modules...

Initializing the backend...
Terraform has detected you're unconfiguring your previously set "s3" backend.
Do you want to copy existing state to the new backend?
  Pre-existing state was found while migrating the previous "s3" backend to the
  newly configured "local" backend. No existing state was found in the newly
  configured "local" backend. Do you want to copy this state to the new "local"
  backend? Enter "yes" to copy and "no" to start with an empty state.

  Enter a value: yes
    
Successfully unset the backend "s3". Terraform will now operate locally.

terraform init -reconfigure尽管 Terraform 明确告诉我,是否无法通过转换状态?如果是这样,具体terraform init -reconfigure做什么?

4

2 回答 2

0

下面的解决方法为我解决了这个问题。

在下面添加并运行 terraform init

terraform {后端“本地”{}}

于 2022-01-22T07:23:17.683 回答
0

从官方文档1来看,它似乎-reconfigure有点破坏性,因为它忽略了现有的配置。我认为,如果您对后端进行了更改,然后运行了命令,那么它只会在假设这是一个新配置的情况下起作用。我最近才自己阅读文档,但我不知道这是行为。

所以,回到你的问题,我假设-migrate-state是在不同后端之间迁移状态时使用的所需选项。我从您的问题中了解到,使用terraform init -migrate-state?

于 2021-11-10T12:27:02.380 回答