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)。
我正在尝试了解 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)。