terraform plan 通知基础设施的变化,但也说没有变化

Waq*_*han 2 terraform terraform-provider-gcp

当我跑

它显示了 Terraform 所做更改的列表,并在输出结束时通知“没有更改。您的基础设施与配置匹配。”:

Note: Objects have changed outside of Terraform

Terraform detected the following changes made outside of Terraform since the last "terraform apply":

  # google_sql_database_instance.db1 has been changed
  ~ resource "google_sql_database_instance" "db1" {
        id                            = "db1"
        name                          = "db1"
        # (12 unchanged attributes hidden)

....
whole list of objects to update
....
....

Unless you have made equivalent changes to your configuration, or ignored the relevant attributes using ignore_changes, the following plan may include actions to undo or respond to these changes.

????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????

No changes. Your infrastructure matches the configuration.

Your configuration already matches the changes detected above. If you'd like to update the Terraform state to match, create and apply a refresh-only plan:
  terraform apply -refresh-only
Run Code Online (Sandbox Code Playgroud)

不知道为什么它首先说基础设施发生了变化,但又说配置与基础设施相匹配。我运行了一个测试“Apply”,Terraform 没有改变任何东西,但我想知道为什么它会显示这两个不同的语句,并且还想确保没有任何意外变化。

Mar*_*ins 7

当 Terraform 创建计划时,它会为您的每个资源实例执行两个单独的操作:

  • 从远程系统读取与对象关联的最新值,以确保 Terraform 考虑到您在 Terraform 之外所做的任何更改。
  • 将更新的对象与配置进行比较,看看是否有任何差异,如果有,建议 Terraform 将采取的操作,以使远程对象与配置匹配。

您分享的输出是关于这两个步骤的。Terraform 首先报告说,当它读取最新值时,它检测到Terraform 之外的某些事情已经发生了变化,并解释了它检测到的内容。然后它将这些更新的对象与您的配置进行比较,发现您的配置已经匹配,因此 Terraform 不需要对您的基础设施进行任何额外的更改。

输出的最后一段包括“您的配置已经与上面检测到的更改匹配”,这表明您对 Terraform 之外的对象进行了一些更改,但您更新了配置以匹配。因此,Terraform 不需要对远程对象进行任何更改以使它们与配置匹配,因为 Terraform 以外的其他东西已经更新了它们。