我偶然发现一个非常微妙的问题,试图为我部署在K8S上的应用实现ConfigMap属性源的实时重载。
下面是我当前项目的一些配置片段。
application.yaml
spring:
application:
name: myapp
cloud:
kubernetes:
config:
enabled: true
name: myapp
namespace: myapp
sources:
- namespace: myapp
name: myapp-configmap
reload:
enabled: true
mode: event
strategy: refresh
refresh:
refreshable:
- com.myapp.PropertiesConfig
extra-refreshable:
- javax.sql.DataSource
myapp-deployment.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
name: myapp
name: myapp
namespace: myapp
spec:
replicas: 1
selector:
matchLabels:
name: myapp-backend
strategy:
rollingUpdate:
maxUnavailable: 0
template:
metadata:
labels:
name: myapp-backend
spec:
serviceAccountName: myapp-config-reader
volumes:
- name: myapp-configmap
configMap:
name: myapp-configmap
containers:
- name: myapp
image: eu.gcr.io/myproject/myapp:latest
volumeMounts:
- name: myapp-configmap
mountPath: /config
ports:
- containerPort: 8080
envFrom:
- configMapRef:
name: myapp-configmap
env:
- name: DATASOURCE_PASSWORD
valueFrom:
secretKeyRef:
name: myapp-db-credentials
key: password
我的应用-配置图.yml
apiVersion: v1
kind: ConfigMap
metadata:
name: myapp-configmap
namespace: myapp
data:
SPRING_PROFILES_ACTIVE: dtest
application.yml: |-
reload.message: 1
PropertiesConfig.java
@Data
@Configuration
@ConfigurationProperties(prefix = "reload")
public class PropertiesConfig {
private String message;
}
我在我的maven POM中使用了以下的依赖关系,我可以成功地将myapp部署到我的K8S集群。
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.2.4.RELEASE</version>
</parent>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-kubernetes-config</artifactId>
<version>1.1.1.RELEASE</version>
</dependency>
我可以成功地将myapp部署到我的K8S集群上。
我有一个预定的任务在打印 propertiesConfig.getMessage()
每10秒。因此,当我的应用程序启动时,我在日志中看到一连串的 "1"。
紧接着,我将我的reload.message ConfigMap的属性改为 "2"。发生了什么?
此外,我还尝试了其他组合:模式轮询,策略重启_上下文,等等。但是... 我肯定要事件+刷新! 这是我们用例所需的解决方案。
我的问题是:我可以设置某种 "延迟 "吗?
项目中的application.yml文件和configmap中描述的文件有冲突,不知为何。
我把项目中的那个文件改名为 bootstrap.yml