"default_secret_name" 在 Kubernetes v1.24.0 及以上版本不再适用。

huangapple go评论56阅读模式
英文:

"default_secret_name" is no longer applicable for Kubernetes v1.24.0 and above

问题

我使用Terraform的工作负载身份模块,以在Google Cloud中创建Kubernetes服务账户。当我应用更改时,我收到以下警告。

> "default_secret_name" 不再适用于 Kubernetes v1.24.0 及以上 │ │ 使用
> module.app-workload-identity.kubernetes_service_account_v1.main, │
> 在 ../../modules/workload-identity/main.tf 第 57 行,在资源
> "kubernetes_service_account_v1" "main": │ 57: 资源
> "kubernetes_service_account_v1" "main" { │ │ 从版本
> 1.24.0 开始,Kubernetes 不会自动生成服务账户的令牌,在这种情况下,“default_secret_name” 将是 │ 空的

Workload-Identity main.tf

locals {
  service_account_tmp = var.google_service_account_email== "" ? "projects/${var.project_id}/serviceAccounts/cloudsql-sa@${var.project_id}.iam.gserviceaccount.com" : var.google_service_account_email
  service_id = "projects/${var.project_id}/serviceAccounts/cloudsql-sa@${var.project_id}.iam.gserviceaccount.com"
  k8s_sa_gcp_derived_name = "serviceAccount:${var.project_id}.svc.id.goog[${var.namespace}/${local.output_k8s_name}]"
  gcp_sa_email            = var.google_service_account_email

  # This will cause terraform to block returning outputs until the service account is created
  k8s_given_name       = var.k8s_sa_name != null ? var.k8s_sa_name : var.name
  output_k8s_name      = var.use_existing_k8s_sa ? local.k8s_given_name : kubernetes_service_account.main[0].metadata[0].name
  output_k8s_namespace = var.use_existing_k8s_sa ? var.namespace : kubernetes_service_account.main[0].metadata[0].namespace
}

# resource "google_service_account" "cluster_service_account" {
  # GCP service account ids must be < 30 chars matching regex ^[a-z](?:[-a-z0-9]{4,28}[a-z0-9])$
  # KSA do not have this naming restriction.
  # account_id   = substr(var.name, 0, 30)
  # display_name = substr("GCP SA bound to K8S SA ${local.k8s_given_name}", 0, 100)
  # project      = var.project_id
# }
resource "kubernetes_namespace" "k8s_namespace" {
  metadata {
    name = var.namespace
  }
}

# resource "kubernetes_secret_v1" "main" {
#  metadata {
#    name      = var.name
#    namespace = var.namespace
#    annotations = {
#      "kubernetes.io/service-account.name"      = kubernetes_service_account_v1.main.metadata.0.name
#      "kubernetes.io/service-account.namespace" = kubernetes_service_account_v1.main.metadata.0.namespace
#    }
#    generate_name = "${kubernetes_service_account_v1.main.metadata.0.name}-token-"
#  }
#  type = "kubernetes.io/service-account-token"
#  wait_for_service_account_token = true
#}

resource "kubernetes_service_account" "main" {
  count = var.use_existing_k8s_sa ? 0 : 1
  metadata {
    name      = var.name
    namespace = var.namespace
    annotations = {
      "iam.gke.io/gcp-service-account" = var.google_service_account_email
    }
  }
}


module "annotate-sa" {
  source  = "terraform-google-modules/gcloud/google//modules/kubectl-wrapper"
  version = "~> 2.0.2"

  enabled          = var.use_existing_k8s_sa && var.annotate_k8s_sa
  skip_download    = true
  cluster_name     = var.cluster_name
  cluster_location = var.location
  project_id       = var.project_id

  kubectl_create_command  = "kubectl annotate --overwrite sa -n ${local.output_k8s_namespace} ${local.k8s_given_name} iam.gke.io/gcp-service-account=${local.gcp_sa_email}"
  kubectl_destroy_command = "kubectl annotate sa -n ${local.output_k8s_namespace} ${local.k8s_given_name} iam.gke.io/gcp-service-account-"
}

resource "google_service_account_iam_member" "main" {
  service_account_id = local.service_id
  role               = "roles/iam.workloadIdentityUser"
  member             = local.k8s_sa_gcp_derived_name
}

根据 文档,我尝试添加资源 "kubernetes_secret_v1" 以创建服务账户令牌。但仍然收到相同的警告消息。

英文:

I'm using Terraform workload-identity module , to create Kubernetes service account in Google Cloud. When i apply the changes, I'm getting below warning.

> "default_secret_name" is no longer applicable for Kubernetes v1.24.0
> and above │ │ with
> module.app-workload-identity.kubernetes_service_account_v1.main, │
> on ../../modules/workload-identity/main.tf line 57, in resource
> "kubernetes_service_account_v1" "main": │ 57: resource
> "kubernetes_service_account_v1" "main" { │ │ Starting from version
> 1.24.0 Kubernetes does not automatically generate a token for service accounts, in this case, "default_secret_name" will be │ empty

Workload-Identity main.tf

locals {
  service_account_tmp = var.google_service_account_email== &quot;&quot; ? &quot;projects/${var.project_id}/serviceAccounts/cloudsql-sa@${var.project_id}.iam.gserviceaccount.com&quot; : var.google_service_account_email
  service_id = &quot;projects/${var.project_id}/serviceAccounts/cloudsql-sa@${var.project_id}.iam.gserviceaccount.com&quot;
  k8s_sa_gcp_derived_name = &quot;serviceAccount:${var.project_id}.svc.id.goog[${var.namespace}/${local.output_k8s_name}]&quot;
  gcp_sa_email            = var.google_service_account_email

  # This will cause terraform to block returning outputs until the service account is created
  k8s_given_name       = var.k8s_sa_name != null ? var.k8s_sa_name : var.name
  output_k8s_name      = var.use_existing_k8s_sa ? local.k8s_given_name : kubernetes_service_account.main[0].metadata[0].name
  output_k8s_namespace = var.use_existing_k8s_sa ? var.namespace : kubernetes_service_account.main[0].metadata[0].namespace
}

# resource &quot;google_service_account&quot; &quot;cluster_service_account&quot; {
  # GCP service account ids must be &lt; 30 chars matching regex ^[a-z](?:[-a-z0-9]{4,28}[a-z0-9])$
  # KSA do not have this naming restriction.
  # account_id   = substr(var.name, 0, 30)
  # display_name = substr(&quot;GCP SA bound to K8S SA ${local.k8s_given_name}&quot;, 0, 100)
  # project      = var.project_id
# }
resource &quot;kubernetes_namespace&quot; &quot;k8s_namespace&quot; {
  metadata {
    name = var.namespace
  }
}

# resource &quot;kubernetes_secret_v1&quot; &quot;main&quot; {
#  metadata {
#    name      = var.name
#    namespace = var.namespace
#    annotations = {
#      &quot;kubernetes.io/service-account.name&quot;      = kubernetes_service_account_v1.main.metadata.0.name
#      &quot;kubernetes.io/service-account.namespace&quot; = kubernetes_service_account_v1.main.metadata.0.namespace
#    }
#    generate_name = &quot;${kubernetes_service_account_v1.main.metadata.0.name}-token-&quot;
#  }
#  type = &quot;kubernetes.io/service-account-token&quot;
#  wait_for_service_account_token = true
#}

resource &quot;kubernetes_service_account&quot; &quot;main&quot; {
  count = var.use_existing_k8s_sa ? 0 : 1
  metadata {
    name      = var.name
    namespace = var.namespace
    annotations = {
      &quot;iam.gke.io/gcp-service-account&quot; = var.google_service_account_email
    }
  }
}


module &quot;annotate-sa&quot; {
  source  = &quot;terraform-google-modules/gcloud/google//modules/kubectl-wrapper&quot;
  version = &quot;~&gt; 2.0.2&quot;

  enabled          = var.use_existing_k8s_sa &amp;&amp; var.annotate_k8s_sa
  skip_download    = true
  cluster_name     = var.cluster_name
  cluster_location = var.location
  project_id       = var.project_id

  kubectl_create_command  = &quot;kubectl annotate --overwrite sa -n ${local.output_k8s_namespace} ${local.k8s_given_name} iam.gke.io/gcp-service-account=${local.gcp_sa_email}&quot;
  kubectl_destroy_command = &quot;kubectl annotate sa -n ${local.output_k8s_namespace} ${local.k8s_given_name} iam.gke.io/gcp-service-account-&quot;
}

resource &quot;google_service_account_iam_member&quot; &quot;main&quot; {
  service_account_id = local.service_id
  role               = &quot;roles/iam.workloadIdentityUser&quot;
  member             = local.k8s_sa_gcp_derived_name
}

As per the this documentation , I have tried to add the resource "kubernetes_secret_v1" to create a service account token. But still getting the same warning message.

答案1

得分: 2

从这个 git issue 中,kubernetes_service_account 问题已成功修复,使用了这个 manifest

我发现了这个 替代解决方案,可以使用 terraform 资源 kubernetes_manifest 手动生成服务账户及其密钥来进行更改。

你可以尝试使用 main.tf 文件,然后告诉我这是否有效。

欲了解更多信息,请查看此 Issue

英文:

From this git issue kubernetes_service_account issue has been successfully fixed using this manifest.

I found this alternative solution where changes are made using the terraform resource kubernetes_manifest to manually generate the service accounts along with their secret.

Can you try the main.tf file and let me know if this works.

For more information follow this Issue.

答案2

得分: 1

我们最近遇到了类似的问题。对我们有用的是在 kubernetes_service_account_v1 Terraform 资源中定义 secret

以下是一个示例:

资源 "kubernetes_service_account_v1" "svc_test" {
   metadata {
      name = "svc-test"
      namespace = "test"
   }
   secret {
    name = "svc-test-token"
  }
}

资源 "kubernetes_secret_v1" "svc_test_token" {
  metadata {
    name = "${kubernetes_service_account_v1.svc_test.metadata[0].name}-token"
    annotations = {
      "kubernetes.io/service-account.name" = kubernetes_service_account_v1.svc_test.metadata[0].name
    }
    namespace = "test"
    generate_name = "${kubernetes_service_account_v1.svc_test.metadata[0].name}-token"

  }
  type = "kubernetes.io/service-account-token"

  wait_for_service_account_token = true
}

我们发现,如果没有这个,secret 会被创建为 serviceaccount 的引用,但 serviceaccount 中没有 secret 的引用。

希望能对您有所帮助。

英文:

We faced a similar issue very recently. What worked for us was defining the secret in the kubernetes_service_account_v1 terraform resource.

Here's an example:

resource &quot;kubernetes_service_account_v1&quot; &quot;svc_test&quot; {
   metadata {
      name = &quot;svc-test&quot;
      namespace = &quot;test&quot;
   }
   secret {
    name = &quot;svc-test-token&quot;
  }
}

resource &quot;kubernetes_secret_v1&quot; &quot;svc_test_token&quot; {
  metadata {
    name = &quot;${kubernetes_service_account_v1.svc_test.metadata[0].name}-token&quot;
    annotations = {
      &quot;kubernetes.io/service-account.name&quot; = kubernetes_service_account_v1.svc_test.metadata[0].name
    }
    namespace = &quot;test&quot;
    generate_name = &quot;${kubernetes_service_account_v1.svc_test.metadata[0].name}-token&quot;

  }
  type = &quot;kubernetes.io/service-account-token&quot;
  
  wait_for_service_account_token = true
}

We found that without this, the secret gets created with the serviceaccount reference but there is no reference of the secret in the serviceaccount.

Hope it helps.

答案3

得分: 0

根据 Terraform AWS 提供商文档关于废弃警告中的信息,service_account_v1 资源中的 default_secret_name 应该使用 kubernetes_secret_v1 资源来创建用于保存服务账号令牌的密钥。这是因为自 Kubernetes 版本 1.24 及更高版本开始,不再自动创建服务账号令牌。只有那些无法使用新的 TokenRequest API(参见 K8s 文档)的旧软件才需要显式创建这些令牌。

在确实需要显式创建带有服务账号令牌的密钥以支持旧行为时,以下方法非常有效:

resource &quot;kubernetes_service_account_v1&quot; &quot;this&quot; {
  provider = kubernetes.minikube
  metadata {
    name      = local.service_account_name
    namespace = local.namespace
  }
}

resource &quot;kubernetes_secret_v1&quot; &quot;this&quot; {
  provider = kubernetes.minikube
  metadata {
    name      = &quot;${kubernetes_service_account_v1.this.metadata[0].name}-token&quot;
    namespace = local.namespace
    annotations = {
      &quot;kubernetes.io/service-account.name&quot; = kubernetes_service_account_v1.this.metadata[0].name
    }
  }
  type = &quot;kubernetes.io/service-account-token&quot;
}
英文:

According to the Terraform AWS provider documentation warning about the deprecation of default_secret_name in service_account_v1 resource, the kubernetes_secret_v1 resource should be used to created the secret to hold the Service Account token, since Service Account tokens are no longer created automatically in K8s versions starting 1.24 and beyond. These explicitly created tokens are only needed by legacy software, which are unable to use the new TokenRequest API (see K8s docs).

When you do need to explicitly create a Secret with the Service Account token, to support legacy behavior, the following works very well:

resource &quot;kubernetes_service_account_v1&quot; &quot;this&quot; {
  provider = kubernetes.minikube
  metadata {
    name      = local.service_account_name
    namespace = local.namespace
  }
}

resource &quot;kubernetes_secret_v1&quot; &quot;this&quot; {
  provider = kubernetes.minikube
  metadata {
    name      = &quot;${kubernetes_service_account_v1.this.metadata[0].name}-token&quot;
    namespace = local.namespace
    annotations = {
      &quot;kubernetes.io/service-account.name&quot; = kubernetes_service_account_v1.this.metadata[0].name
    }
  }
  type = &quot;kubernetes.io/service-account-token&quot;
}

"default_secret_name" 在 Kubernetes v1.24.0 及以上版本不再适用。

huangapple
  • 本文由 发表于 2023年4月17日 17:21:26
  • 转载请务必保留本文链接:https://go.coder-hub.com/76033573.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定