Spring Cloud Kubernetes 没有加载像 xx.yy 这样的模式的密钥

问题描述

我正在尝试了解 Spring Cloud Kubernetes 以加载机密,我观察到的是,如果属性具有类似 yml 的结构,则它不会在应用程序中加载。

例如:

kind: Secret
Metadata:
  name: activemq-secrets
  labels:
    broker: activemq
type: Opaque
data:
  amqusername: bXl1c2VyCg==
  amq.password: MWYyZDFlMmU2N2Rm

K8 清单

  template:
    spec:
      volumes: 
        - name: secretvolume
          secret:
            secretName: activemq-secrets
      containers:
        -
          volumeMounts: 
            - name: secretvolume
              readOnly: true
              mountPath: /etc/secrets/

jvm 参数:

-Dspring.cloud.kubernetes.secrets.paths=/etc/secrets/
-Dspring.cloud.kubernetes.secrets.enabled=true

尝试加载@Value("${amqusername}")作品

但是当我尝试使用 @Value("${amq.password}") 读取此属性时,我收到了未找到占位符的错误。我试过打印所有 spring 配置,但没有显示。我该如何解决这个问题。

解决方法

尝试将secret中的变量名改为amq_password

更新

如果您使用环境变量而不是系统属性,大多数操作系统不允许使用句点分隔的键名,但您可以使用下划线代替(例如 SPRING_CONFIG_NAME 而不是 spring.config.name)。

https://docs.spring.io/spring-boot/docs/1.5.6.RELEASE/reference/html/boot-features-external-config.html