溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Springboot如何整合Spring Cloud Kubernetes讀取ConfigMap

發(fā)布時間:2021-12-16 17:10:43 來源:億速云 閱讀:423 作者:小新 欄目:大數(shù)據(jù)

這篇文章將為大家詳細講解有關(guān)Springboot如何整合Spring Cloud Kubernetes讀取ConfigMap,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

1 前言

之前介紹了Spring Cloud Config的用法,但對于Kubernetes應(yīng)用,可能會需要讀取ConfigMap的配置,我們看看Springboot是如何方便地讀取ConfigMapSecret。

2 整合Spring Cloud Kubenetes

Spring Cloud Kubernetes提供了Spring Cloud應(yīng)用與Kubernetes服務(wù)關(guān)聯(lián),我們也可以自己寫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 WebSpring Cloud Kubernetes Config即可,很簡單。

Springboot啟動類:

@SpringBootApplication
public class ConfigMapMain {
    public static void main(String[] args) {
        SpringApplication.run(ConfigMapMain.class, args);
    }
}

準(zhǔn)備一個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讀取。

應(yīng)用的配置文件如下:

server:
  port: 8080
spring:
  application:
    name: spring-cloud-kubernetes-configmap
  cloud:
    kubernetes:
      config:
        name: spring-cloud-kubernetes-configmap

這里的spring.cloud.kubernetes.config.name是重點,后續(xù)要通過它來找ConfigMap。

加密密碼:

$ echo -n "pkslow-pass" | base64 
cGtzbG93LXBhc3M=

創(chuàng)建Kubernetes Secret

kind: Secret
apiVersion: v1
metadata:
  name: spring-cloud-kubernetes-secret
  namespace: default
data:
  pkslow.password: cGtzbG93LXBhc3M=
type: Opaque

ConfigMap的內(nèi)容如下:

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。

接著完成DockerfileK8s部署文件就可以了。注意要將Secret的值映射到環(huán)境變量:

env:
	- name: PKSLOW_PASSWORD
		valueFrom:
			secretKeyRef:
				name: spring-cloud-kubernetes-secret
				key: pkslow.password

2.2 啟動與測試

應(yīng)用會在啟動時就去Kubernetes找相應(yīng)的ConfigMapSecret

  .   ____          _            __ _ _
 /\\ / ___'_ __ _ _(_)_ __  __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
 \\/  ___)| |_)| | | | | || (_| |  ) ) ) )
  '  |____| .__|_| |_|_| |_\__, | / / / /
 =========|_|==============|___/=/_/_/_/
 :: Spring Boot ::        (v2.2.5.RELEASE)

2020-08-25 00:13:17.374  INFO 7 --- [           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,可以正確讀取配置,ConfigMapSecret的內(nèi)容都獲取到了:

Springboot如何整合Spring Cloud Kubernetes讀取ConfigMap

3 自動刷新配置

3.1 原理介紹與代碼變更

我們需要在Web運行過程中修改配置并使配置生效,有多種模式。修改配置文件如下:

server:
  port: 8080
spring:
  application:
    name: spring-cloud-kubernetes-configmap
  cloud:
    kubernetes:
      config:
        name: spring-cloud-kubernetes-configmap
        namespace: 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會優(yōu)雅重啟,里面的所有配置都會重新加載。

需要打開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監(jiān)控ConfigMap的變更,讀取配置并生效。

  • Polling:定期查看是否有變化,有變化則觸發(fā),默認為15秒。

3.2 測試

我們修改一下ConfigMap的配置,并更新到K8s

$ kubectl apply -f src/main/k8s/config.yaml 
configmap/spring-cloud-kubernetes-configmap configured

查看發(fā)現(xiàn)ageemail都修改了:

Springboot如何整合Spring Cloud Kubernetes讀取ConfigMap

我們查看一下Pod的日志如下:

Springboot如何整合Spring Cloud Kubernetes讀取ConfigMap

Springboot先是檢測到了ConfigMap有了變更,然后觸發(fā)Context重啟。

關(guān)于“Springboot如何整合Spring Cloud Kubernetes讀取ConfigMap”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI