中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》
  • 首頁 > 
  • 教程 > 
  • 開發技術 > 
  • Springboot整合Spring Cloud Kubernetes讀取ConfigMap支持自動刷新配置的教程

Springboot整合Spring Cloud Kubernetes讀取ConfigMap支持自動刷新配置的教程

發布時間:2020-09-17 15:58:03 來源:腳本之家 閱讀:206 作者:南瓜慢說 欄目:開發技術

1 前言

歡迎訪問南瓜慢說 www.pkslow.com獲取更多精彩文章!

Docker & Kubernetes相關文章:容器技術

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

2 整合Spring Cloud Kubenetes

Spring Cloud Kubernetes提供了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 WebSpring 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

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

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

2.2 啟動與測試

應用會在啟動時就去Kubernetes找相應的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'}]}

訪問spring-cloud-kubernetes-configmap.localhost/pkslow,可以正確讀取配置,ConfigMapSecret的內容都獲取到了:

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會優雅重啟,里面的所有配置都會重新加載。

需要打開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

查看發現ageemail都修改了:

Springboot整合Spring Cloud Kubernetes讀取ConfigMap支持自動刷新配置的教程

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

Springboot整合Spring Cloud Kubernetes讀取ConfigMap支持自動刷新配置的教程

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

4 總結

Spring Cloud Kubernetes為我們提供了不少Spring Cloud整合Kubernetes的特性,可以引入使用。

到此這篇關于Springboot整合Spring Cloud Kubernetes讀取ConfigMap支持自動刷新配置的文章就介紹到這了,更多相關Springboot整合Spring Cloud Kubernetes內容請搜索億速云以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持億速云!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

平顺县| 海淀区| 洪泽县| 台中市| 汾阳市| 崇礼县| 林周县| 团风县| 崇文区| 丰顺县| 榆社县| 仁布县| 阜阳市| 眉山市| 宿迁市| 韶山市| 比如县| 甘肃省| 阳谷县| 京山县| 巨野县| 彭泽县| 梁山县| 余姚市| 汾阳市| 怀柔区| 瓮安县| 夏邑县| 垣曲县| 三都| 平昌县| 嘉善县| 唐山市| 大荔县| 南郑县| 江北区| 沙湾县| 宾川县| 桐城市| 弥勒县| 镶黄旗|