【问题标题】:Unable to create App Engine App from Terraform: The caller does not have permission, forbidden无法从 Terraform 创建 App Engine 应用程序:调用者没有权限,被禁止
【发布时间】:2022-01-15 11:05:19
【问题描述】:

我有以下 Terraform:

data "google_client_config" "current" {
}

resource "google_app_engine_application" "app" {
  project     = data.google_client_config.current.project
  location_id = "us-central"
}

当我运行它时,我收到以下错误:

Error creating App Engine application: googleapi: Error 403: The caller does not have permission, forbidden

我已经在项目中为运行 Terraform 的服务帐户分配了Owner 角色。

我不确定我还能尝试什么。我发现的所有内容都与将此角色授予执行该操作的帐户有关。

【问题讨论】:

  • 如何将具有 Owner 角色的服务帐户分配给 Terraform?一个常见的问题是您没有使用您认为的身份。
  • 或者他可能无法访问正确的项目 ID,请在此处使用示例进行测试:registry.terraform.io/providers/hashicorp/google/latest/docs/…
  • 凭据正在通过 GOOGLE_APPLICATION_CREDENTIALS 传入。我将尝试查看是否可以以某种方式验证该帐户是否是我认为的帐户。这个 terraform 是另一个模块的一部分,除了那个之外,所有其他资源都正常工作。
  • 对此的部分限制是我无法修改 Terraform。此 Terraform 已在其他环境中运行并在过去工作过。我正在尝试在新环境中运行它,而设置它的人不再使用它。我正在尝试查看我可能缺少哪些权限或可能配置错误的权限,从而导致此操作失败。

标签: google-app-engine google-cloud-platform terraform


【解决方案1】:

发生这种情况的原因是我误解了提供程序配置的工作原理。

在我们的提供程序中,正在设置 access_token 字段。我认为GOOGLE_APPLICATION_CREDENTIALS 变量会覆盖 Terraform 代码中提供程序上设置的任何内容,但事实证明access_token 并非如此。 GOOGLE_APPLICATION_CREDENTIALS 实际上什么也没做。

【讨论】:

    猜你喜欢
    • 2020-06-02
    • 2017-07-28
    • 2020-11-16
    • 2017-05-21
    • 2020-04-07
    • 1970-01-01
    • 1970-01-01
    • 2019-12-15
    • 2021-08-26
    相关资源
    最近更新 更多