這篇博文,咱們來講一說,關於在kubernetes的pod中自定義配置的問題。mysql
咱們知道,在幾乎全部的應用開發中,都會涉及到配置文件的變動,好比說在web的程序中,須要鏈接數據庫,緩存甚至是隊列等等。而咱們的一個應用程序從寫第一行代碼開始,要經歷開發環境、測試環境、預發佈環境只到最終的線上環境。而每個環境都要定義其獨立的各類配置。若是咱們不能很好的管理這些配置文件,你的運維工做將頓時變的無比的繁瑣。爲此業內的一些大公司專門開發了本身的一套配置管理中心,如360的Qcon,百度的disconf等。kubernetes也提供了本身的一套方案,即ConfigMap。kubernetes經過ConfigMap來實現對容器中應用的配置管理。web
建立ConfigMap的方式有兩種,一種是經過yaml文件來建立,另外一種是經過kubectl直接在命令行下建立。sql
咱們先來看第一種,在yaml文件中,配置文件以key-value鍵值對的形式保存,固然也能夠直接放一個完整的配置文件,在下面的示例中,cache_hst、cache_port、cache_prefix便是key-value鍵值對,而app.properties和my.cnf都是配置文件:數據庫
apiVersion: v1 kind: ConfigMap metadata: name: test-cfg namespace: default data: cache_host: memcached-gcxt cache_port: "11211" cache_prefix: gcxt my.cnf: | [mysqld] log-bin = mysql-bin app.properties: | property.1 = value-1 property.2 = value-2 property.3 = value-3
建立ConfigMap:api
kubectl create -f test-cfg.yml
第二種方式是直接使用kubectl在命令行下建立緩存
直接將一個目錄下的全部配置文件建立爲一個ConfigMap:app
kubectl create configmap test-config --from-file=./configs
直接將一個配置文件建立爲一個ConfigMap:運維
kubectl create configmap test-config2 --from-file=./configs/db.conf --from-file=./configs/cache.conf
在使用kubectl建立的時候,經過在命令行直接傳遞鍵值對建立:memcached
kubectl create configmap test-config3 --from-literal=db.host=10.5.10.116 --from-listeral=db.port='3306'
咱們能夠經過以下方式查看建立的ConfigMap:測試
kubectl get configmaps kubectl get configmap test-config -o yaml kubectl describe configmap test-config
使用ConfigMap有三種方式,一種是經過環境變量的方式,直接傳遞pod,另外一種是經過在pod的命令行下運行的方式,第三種是使用volume的方式掛載入到pod內
第一種方式示例:
ConfigMap文件:
apiVersion: v1 kind: ConfigMap metadata: name: special-config namespace: default data: special.how: very special.type: charm
第一個pod示例:
apiVersion: v1 kind: Pod metadata: name: dapi-test-pod spec: containers: - name: test-container image: gcr.io/google_containers/busybox command: [ "/bin/sh", "-c", "env" ] env: - name: SPECIAL_LEVEL_KEY valueFrom: configMapKeyRef: name: special-config key: special.how - name: SPECIAL_TYPE_KEY valueFrom: configMapKeyRef: name: special-config key: special.type restartPolicy: Never
第二個pod示例:
apiVersion: v1 kind: Pod metadata: name: dapi-test-pod spec: containers: - name: test-container image: gcr.io/google_containers/busybox command: [ "/bin/sh", "-c", "env" ] env: - name: CACHE_HOST valueFrom: configMapKeyRef: name: test-cfg key: cache_host optional: true restartPolicy: Never
第二種方式在命令行下引用時,須要先設置爲環境變量,以後 能夠經過$(VAR_NAME)設置容器啓動命令的啓動參數,示例:
ConfigMap文件示例:
apiVersion: v1 kind: ConfigMap metadata: name: special-config namespace: default data: special.how: very special.type: charm
Pod示例:
apiVersion: v1 kind: Pod metadata: name: dapi-test-pod spec: containers: - name: test-container image: gcr.io/google_containers/busybox command: [ "/bin/sh", "-c", "echo $(SPECIAL_LEVEL_KEY) $(SPECIAL_TYPE_KEY)" ] env: - name: SPECIAL_LEVEL_KEY valueFrom: configMapKeyRef: name: special-config key: special.how - name: SPECIAL_TYPE_KEY valueFrom: configMapKeyRef: name: special-config key: special.type restartPolicy: Never
第三種方式,使用volume將ConfigMap做爲文件或目錄直接掛載,其中每個key-value鍵值對都會生成一個文件,key爲文件名,value爲內容,下面是一個示例:
ConfigMap示例:
apiVersion: v1 kind: ConfigMap metadata: name: special-config namespace: default data: special.how: very special.type: charm
第一個pod示例,簡單的將上面建立的ConfigMap直接掛載至pod的/etc/config目錄下:
apiVersion: v1 kind: Pod metadata: name: dapi-test-pod spec: containers: - name: test-container image: gcr.io/google_containers/busybox command: [ "/bin/sh", "-c", "cat /etc/config/special.how" ] volumeMounts: - name: config-volume mountPath: /etc/config volumes: - name: config-volume configMap: name: special-config restartPolicy: Never
第二個pod示例,只將ConfigMap的special.how這個key掛載到/etc/config目錄下的一個相對路徑path/to/special-key,若是存在同名文件,直接覆蓋。其餘的key不掛載:
apiVersion: v1 kind: Pod metadata: name: dapi-test-pod spec: containers: - name: test-container image: gcr.io/google_containers/busybox command: [ "/bin/sh","-c","cat /etc/config/path/to/special-key" ] volumeMounts: - name: config-volume mountPath: /etc/config volumes: - name: config-volume configMap: name: special-config items: - key: special.how path: path/to/special-key restartPolicy: Never
最後須要說明兩點:
一、ConfigMap必須在Pod以前建立
二、只有與當前ConfigMap在同一個namespace內的pod才能使用這個ConfigMap,換句話說,ConfigMap不能跨命名空間調用。