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

Spring Cloud Kubernetes is not loading secret keys with pattern like 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