如何使用 Terraform 通过 YAML 部署 Kubernetes 服务?

alt*_*-f4 4 kubernetes terraform

我正在学习 Kubernetes,我的目标是部署 Kubernetes,但通过 terraform(Kubernetes 提供程序)使用 Yaml 文件。让我用一个例子来说明:

了解,我可以将 ConfigMap 作为资源,例如:

resource "kubernetes_config_map" "config" {
  metadata {
    namespace = "metallb_system"
    name = "config"
  }
  data {
    config = "${file(${path.module}/config.yml)}"
  }
}
Run Code Online (Sandbox Code Playgroud)

现在我想部署一个服务,在 HCL 中如下所示:

resource "kubernetes_service" "nginx" {

  metadata {
    name = "nginx-example-bla"
  }
  spec {
    selector = {
      App = kubernetes_pod.airflow.metadata[0].labels.App
    }
    port {
      port        = 80
      target_port = 8080
    }

    type = "LoadBalancer"
  }
}
Run Code Online (Sandbox Code Playgroud)

但我想用 yaml 而不是 HCL 来完成。

所以(假设),我希望能够做类似的事情:

resource "kubernetes_service" "nginx" {
  file = kubernetes_config_map.config  # Not sure if ConfigMap is the right usage here but I want to be able to deploy a service through Yaml
}
Run Code Online (Sandbox Code Playgroud)

Mar*_*sch 5

Terraform 仅跟踪使用 HCL 添加的资源,file()仅使用添加的内容。因此,如果您希望 terraform 管理您的 k8s 资源(检测这些资源的更改或删除),您必须坚持这样做。

如果您只想使用 terraform 部署 YAML 文件,则可以使用“null_resource”运行命令:

resource "null_resource" "deploy-yaml" {

  provisioner "local-exec" {
      command = "kubectl apply -f xxx.yaml"
  }
}
Run Code Online (Sandbox Code Playgroud)

如果您这样做,请记住,该 terraform 现在没有任何更改检测。因此,如果 YAML 发生更改,terraform 不会知道。您必须通过快速而肮脏地更改资源名称或使用一些始终变化的值(例如 random_uuid)来重新运行脚本来触发它。