Springboot整合Spring Cloud Kubernetes读取ConfigMap,支持自动刷新配置
2020-09-04 00:46
2476 查看
1 前言
欢迎访问南瓜慢说 www.pkslow.com获取更多精彩文章!
Docker & Kubernetes相关文章:容器技术
之前介绍了
Spring Cloud Config的用法,但对于
Kubernetes应用,可能会需要读取
ConfigMap的配置,我们看看
Springboot是如何方便地读取
ConfigMap和
Secret。
2 整合Spring Cloud Kubenetes
Spring Cloud应用与
Kubernetes服务关联,我们也可以自己写
Java程序来获取
Kubernetes的特性,但
Spring又为我们做了。
2.1 项目代码
引入依赖:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-kubernetes-config</artifactId> </dependency>
只需要
Springboot Web和
Spring Cloud Kubernetes Config即可,很简单。
Springboot启动类:
@SpringBootApplication public class ConfigMapMain { public static void main(String[] args) { SpringApplication.run(ConfigMapMain.class, args); } }
准备一个
EndPoint来展示所读到的配置信息:
@RestController public class PkslowController { @Value("${pkslow.age:0}") private Integer age; @Value("${pkslow.email:null}") private String email; @Value("${pkslow.webSite:null}") private String webSite; @Value("${pkslow.password:null}") private String password; @GetMapping("/pkslow") public Map<String, String> getConfig() { Map<String, String> map = new HashMap<>(); map.put("age", age.toString()); map.put("email", email); map.put("webSite", webSite); map.put("password", password); return map; } }
默认是为空的,
password是从
Secret读取,其它从
ConfigMap读取。
应用的配置文件如下:
server: port: 8080 spring: application: name: spring-cloud-kubernetes-configmap cloud: kubernetes: config: name: spring-cloud-kubernetes-configmap
这里的
spring.cloud.kubernetes.config.name是重点,后续要通过它来找
ConfigMap。
加密密码:
$ echo -n "pkslow-pass" | base64 cGtzbG93LXBhc3M=
创建
Kubernetes Secret:
kind: Secret apiVersion: v1 metadata: name: spring-cloud-kubernetes-secret namespace: default data: pkslow.password: cGtzbG93LXBhc3M= type: Opaque
ConfigMap的内容如下:
kind: ConfigMap apiVersion: v1 metadata: name: spring-cloud-kubernetes-configmap namespace: default labels: app: scdf-server data: application.yaml: |- pkslow: age: 19 email: admin@pkslow.com webSite: www.pkslow.com
要注意的是,这里的名字与前面配置的是一致的,都是
spring-cloud-kubernetes-configmap。
接着完成
Dockerfile和
K8s部署文件就可以了。注意要将
Secret的值映射到环境变量:
env: - name: PKSLOW_PASSWORD valueFrom: secretKeyRef: name: spring-cloud-kubernetes-secret key: pkslow.password
2.2 启动与测试
应用会在启动时就去
Kubernetes找相应的
ConfigMap和
Secret:
. ____ _ __ _ _ /\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \ ( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \ \\/ ___)| |_)| | | | | || (_| | ) ) ) ) ' |____| .__|_| |_|_| |_\__, | / / / / =========|_|==============|___/=/_/_/_/ :: Spring Boot :: (v2.2.5.RELEASE) 2020-08-25 00:13:17.374 INFO 7 --- [ 15b0 main] b.c.PropertySourceBootstrapConfiguration : Located property source: CompositePropertySource {name='composite-configmap', propertySources=[ConfigMapPropertySource {name='configmap.spring-cloud-kubernetes-configmap.default'}]} 2020-08-25 00:13:17.376 INFO 7 --- [ main] b.c.PropertySourceBootstrapConfiguration : Located property source: CompositePropertySource {name='composite-secrets', propertySources=[]}
访问
spring-cloud-kubernetes-configmap.localhost/pkslow,可以正确读取配置,
ConfigMap和
Secret的内容都获取到了:
3 自动刷新配置
3.1 原理介绍与代码变更
我们需要在
Web运行过程中修改配置并使配置生效,有多种模式。修改配置文件如下:
server: port: 8080 spring: application: name: spring-cloud-kubernetes-configmap cloud: kubernetes: config: name: spring-cloud-kubernetes-configmapnamespace: default secrets: name: spring-cloud-kubernetes-secret namespace: default enabled: true reload: enabled: true monitoring-config-maps: true monitoring-secrets: true strategy: restart_context mode: event management: endpoint: restart: enabled: true endpoints: web: exposure: include: restart
(1)
spring.cloud.kubernetes.reload.enabled=true需要打开刷新功能;
(2) 加载策略
strategy:
refresh
:只对特定的配置生效,有注解@ConfigurationProperties
或@RefreshScope
。restart_context
:整个Spring Context
会优雅重启,里面的所有配置都会重新加载。
需要打开
actuator endpoint,所以要配置
management.endpoint。还要增加依赖:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-actuator</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-actuator-autoconfigure</artifactId> </dependency>
shutdown
:重启容器。
(3)模式
mode
- 事件
Event
:会通过k8s API
监控ConfigMap
的变更,读取配置并生效。 Polling
:定期查看是否有变化,有变化则触发,默认为15秒。
3.2 测试
我们修改一下
ConfigMap的配置,并更新到
K8s。
$ kubectl apply -f src/main/k8s/config.yaml configmap/spring-cloud-kubernetes-configmap configured
查看发现
age和
我们查看一下
Pod的日志如下:
Springboot先是检测到了
ConfigMap有了变更,然后触发
Context重启。
4 总结
Spring Cloud Kubernetes为我们提供了不少
Spring Cloud整合
Kubernetes的特性,可以引入使用。
配置相关文章:
Springboot整合Spring Cloud Kubernetes读取ConfigMap,支持自动刷新配置
Spring Cloud Config在Spring Cloud Task中的应用,比Web应用更简单
Spring Cloud Config整合Spring Cloud Kubernetes,在k8s上管理配置
使用Spring Cloud Config统一管理配置,别再到处放配置文件了
Java怎么从这四个位置读取配置文件Properties(普通文件系统-classpath-jar-URL)
注解@ConfigurationProperties让配置整齐而简单
Springboot整合Jasypt,让配置信息安全最优雅方便的方式
欢迎关注微信公众号<南瓜慢说>,将持续为你更新...
多读书,多分享;多写作,多整理。
相关文章推荐
- Spring Boot Cache + redis 设置有效时间和自动刷新缓存,时间支持在配置文件中配置
- 从SpringBoot整合Mybatis分析自动配置
- 通过Spring Boot整合Mybatis分析自动配置详解
- (七)SpringBoot的MVC自动配置
- Spring Boot的自动配置
- 006-Spring Boot自动配置-Condition、Conditional
- Spring Boot自动配置原理、实战
- springboot+tomcat针对不同环境自动加载配置
- springboot简单整合dubbo的小demo(基于yml配置)
- 源码学习系列之SpringBoot自动配置(篇二)
- Spring Boot核心原理-自动配置
- 使用SpringBoot整合ActiveMQ自动注入JmsMessagingTemplate时候的问题
- dubbo整合springboot配置
- SpringBoot学习笔记(5) Spring Boot集成Redis实现自动配置
- Spring Boot中的缓存支持(一)注解配置与EhCache使用
- SpringBoot自动配置原理
- 从零开始学springboot-配置jpa自动建表为innodb
- spring boot properties类型安全以及自动配置
- Spring Boot 自动配置(auto-configurtion) 揭秘
- 初识Spring Boot框架(二)之DIY一个Spring Boot的自动配置