将 yaml 数组作为环境添加到 kubernetes/kustomize

adding yaml array as env to kubernetes/kustomize

所以,我有一个如下所示的 yaml 文件:

service:
        users:
            - username: some-user
              password: some-pass (would be placed in Secret)
            - username: some-user
              password: some-pass (would be placed in Secret)

我需要将它添加到 env 中(在 spring 启动的优先级列表中,来自 env 的配置高于来自 yaml 的配置。这将基于 env(dev,stage,live))。 我已经用 Kustomize

试过了
configMapGenerator:
    - name: my-java-server-props
      files:
      - config.yaml

然后在部署中使用它

envFrom:
  - configMapRef:
      name: my-java-server-props

config.yml 中的其他配置如下:

spring:
  datasource:
    url: some-url-here

然后像这样为 configMapGenerator 添加 .properties 文件:

spring_datasource_url=some-url-here

但是带数组的配置似乎不起作用。

关于我在哪里遗漏技巧的任何提示? 另外,密码来自credstash;所以,我有一个不同的脚本,它从 credstash 获取值并为 Secret 创建清单。

在部署中添加密码的最终目标是这样的:

name: service_users.0.password
      valueFrom:
        secretKeyRef:
          key: value
          name: service-user-store-password

这是 spring 前段时间引导中的一个问题,支持将环境变量绑定到数组元素。 spring boot wiki 上有一个很好的文档来描述解决方案:https://github.com/spring-projects/spring-boot/wiki/Relaxed-Binding-2.0.

总而言之,数组元素可以使用 i 进行索引,因此在您的情况下:

env:
- name: SERVICE_USERS_0_PASSWORD
  valueFrom:
    secretKeyRef:
      key: value
      name: service-user-store-password
- name: SERVICE_USERS_1_PASSWORD
  valueFrom:
    secretKeyRef:
      key: value
      name: service-another-user-store-password