如何解决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)。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。