2

我正在尝试将以下ConfigMapyaml 文件(此处的链接)转换为 akubernetes_config_map但在尝试定义它时遇到语法错误。

特别是,我无法绕过opentsdb.conf文件中的点符号

apiVersion: v1
kind: ConfigMap
metadata:
  name: opentsdb-config
data:
  opentsdb.conf: |
    google.bigtable.project.id = REPLACE_WITH_PROJECT
    google.bigtable.instance.id = REPLACE_WITH_INSTANCE
    google.bigtable.zone.id = REPLACE_WITH_ZONE
    hbase.client.connection.impl = com.google.cloud.bigtable.hbase1_2.BigtableConnection
    google.bigtable.auth.service.account.enable = true

    tsd.network.port = 4242
    tsd.core.auto_create_metrics = true
    tsd.core.meta.enable_realtime_ts = true
    tsd.core.meta.enable_realtime_uid = true
    tsd.core.meta.enable_tsuid_tracking = true
    tsd.http.request.enable_chunked = true
    tsd.http.request.max_chunk = 131072
    tsd.storage.fix_duplicates = true
    tsd.storage.enable_compaction = false
    tsd.storage.max_tags = 12
    tsd.http.staticroot = /opentsdb/build/staticroot
    tsd.http.cachedir = /tmp/opentsdb

这是我目前的尝试,在"opentsdb.conf"

resource "kubernetes_config_map" "opentsdb" {
  metadata {
    name = "opentsdb-config",
    namespace = "dev"
  }

  data {
    "opentsdb.conf" = {
      google.bigtable.project.id = var.project_id,
      google.bigtable.instance.id = google_bigtable_instance.development-instance.name,
      google.bigtable.zone.id = var.zone,
      hbase.client.connection.impl = "com.google.cloud.bigtable.hbase1_2.BigtableConnection",
      google.bigtable.auth.service.account.enable = true

      tsd.network.port = 4242
      tsd.core.auto_create_metrics = true
      tsd.core.meta.enable_realtime_ts = true
      tsd.core.meta.enable_realtime_uid = true
      tsd.core.meta.enable_tsuid_tracking = true
      tsd.http.request.enable_chunked = true
      tsd.http.request.max_chunk = 131072
      tsd.storage.fix_duplicates = true
      tsd.storage.enable_compaction = false
      tsd.storage.max_tags = 12
      tsd.http.staticroot = "/opentsdb/build/staticroot"
      tsd.http.cachedir = "/tmp/opentsdb"
    }
  }
}
4

1 回答 1

4

我遇到的问题是我试图将一个对象分配给一个字符串文字。

我需要使用EOF如下语法:

resource "kubernetes_config_map" "opentsdb" {
  metadata {
    name = "opentsdb-config"
    namespace = "dev"
  }

  data = {
    "opentsdb.conf" = <<EOF
google.bigtable.project.id = ${var.project_id}
google.bigtable.instance.id = ${var.bigtable_instance_id}
google.bigtable.zone.id = ${var.zone}
hbase.client.connection.impl = com.google.cloud.bigtable.hbase1_2.BigtableConnection
google.bigtable.auth.service.account.enable = true

tsd.network.port = 4242
tsd.core.auto_create_metrics = true
tsd.core.meta.enable_realtime_ts = true
tsd.core.meta.enable_realtime_uid = true
tsd.core.meta.enable_tsuid_tracking = true
tsd.http.request.enable_chunked = true
tsd.http.request.max_chunk = 131072
tsd.storage.fix_duplicates = true
tsd.storage.enable_compaction = false
tsd.storage.max_tags = 12
tsd.http.staticroot = /opentsdb/build/staticroot
tsd.http.cachedir = /tmp/opentsdb
    EOF
  }
}
于 2019-07-23T07:54:53.430 回答