kubernetes存储(一)——ConfigMap配置、管理、应用+热更新

一、comfigmap(简称:cm)简介
Configmap用于保存配置数据,以键值对形式存储。
configMap 资源提供了向 Pod 注入配置数据的方法。
旨在让镜像和配置文件解耦,以便实现镜像的可移植性和可复用性。

典型的使用场景:

填充环境变量的值

设置容器内的命令行参数

填充卷的配置文件

创建ConfigMap的方式有4种:

使用字面值创建
使用文件创建
使用目录创建
编写configmap的yaml文件创建

二、创建cm
清除之前ingress的实验操作

2.1使用字面值创建

从终端录入的数据
key1:key值  config1:value值
第一对:--from-literal=key1=config1  
第二队:--from-literal=key2=config2
创建:
kubectl create configmap my-config --from-literal=key1=config1 --from-literal=key2=config2

在这里插入图片描述
kubernetes存储(一)——ConfigMap配置、管理、应用+热更新_第1张图片
2.2使用文件创建

kubectl create configmap my-config-2 --from-file=/etc/resolv.conf
key的名称是文件名称,value的值是这个文件的内容

kubernetes存储(一)——ConfigMap配置、管理、应用+热更新_第2张图片
2.2.3使用目录创建

kubectl create configmap my-config-3 --from-file=test
目录中的文件名为key,文件内容是value
mkdir test 创建目录
拷贝文件:
cp /etc/resolv.conf
cp /etc/fstab 
 ls  查看
fstab  resolv.conf

[root@server2 ~]# kubectl create configmap my-config-3 --from-file=test
configmap/my-config-3 created
[root@server2 ~]# kubectl get cm
NAME          DATA   AGE
my-config     2      18m
my-config-2   1      9m35s
my-config-3   2      7s

kubernetes存储(一)——ConfigMap配置、管理、应用+热更新_第3张图片
2.2.4编写configmap的yaml文件

[root@server2 cm]# vim cm1.yml 
apiVersion: v1
kind: ConfigMap
metadata:
  name: cm1-config
data:
  db_host: "172.25.254.250"
  db_port: "3306"
[root@server2 cm]# kubectl apply -f cm1.yml 
configmap/cm1-config unchanged
[root@server2 cm]# kubectl describe cm cm1
Name:         cm1-config
Namespace:    default
Labels:       
Annotations:  
Data
====
db_host:
----
172.25.254.250
db_port:
----
3306
Events:  

三、cm的应用
如何使用configmap:

1.通过环境变量的方式直接传递给pod
2.通过在pod的命令行下运行的方式
3.作为volume的方式挂载到pod内

3.1使用configmap设置环境变量
方法一

[root@server2 cm]# vim cm1.yml 
apiVersion: v1
kind: ConfigMap
metadata:
  name: cm1-config
data:
  db_host: "172.25.254.250"
  db_port: "3306"

---
apiVersion: v1
kind: Pod
metadata:
  name: pod1
spec:
  containers:
    - name: pod1
      image: busybox
      command: ["/bin/sh", "-c", "env"]
      env:
        - name: key1
          valueFrom:
            configMapKeyRef:
              name: cm1-config
              key: db_host
        - name: key2
          valueFrom:
            configMapKeyRef:
              name: cm1-config
              key: db_port
  restartPolicy: Never


[root@server2 cm]# kubectl apply -f cm1.yml 
configmap/cm1-config unchanged
pod/pod1 created
[root@server2 cm]# kubectl get pod   pod1运行结束后直接退出
NAME                        READY   STATUS              RESTARTS   AGE
my-nginx-7db4c4f989-j2kbm   0/1     ContainerCreating   0          18m
pod1                        0/1     Completed           0          110s

kubernetes存储(一)——ConfigMap配置、管理、应用+热更新_第4张图片
方法二:
一次性全部注入:cm1-config

apiVersion: v1
kind: ConfigMap
metadata:
  name: cm1-config
data:
  db_host: "172.25.254.250"
  db_port: "3306"

---
apiVersion: v1
kind: Pod
metadata:
  name: pod1
spec:
  containers:
    - name: pod1
      image: busybox
      command: ["/bin/sh", "-c", "env"]
      envFrom:
        - configMapRef:
            name: cm1-config
  restartPolicy: Never

kubernetes存储(一)——ConfigMap配置、管理、应用+热更新_第5张图片
3.2使用conigmap设置命令行参数

[root@server2 cm]# kubectl delete -f cm1.yml 
configmap "cm1-config" deleted
pod "pod1" deleted
[root@server2 cm]# vim cm1.yml 
apiVersion: v1
kind: ConfigMap
metadata:
  name: cm1-config
data:
  db_host: "172.25.254.250"
  db_port: "3306"

---
apiVersion: v1
kind: Pod
metadata:
  name: pod1
spec:
  containers:
    - name: pod1
      image: busybox
      command: ["/bin/sh", "-c", "echo $(db_host) $(db_port)"]
      envFrom:
        - configMapRef:
            name: cm1-config
  restartPolicy: Never

[root@server2 cm]# kubectl apply -f cm1.yml 
configmap/cm1-config created
pod/pod1 created
[root@server2 cm]# kubectl logs pod1 
172.25.254.250 3306

kubernetes存储(一)——ConfigMap配置、管理、应用+热更新_第6张图片
3.3通过数据卷使用configmap

[root@server2 cm]# vim cm1.yml 
 
apiVersion: v1
kind: ConfigMap
metadata:
  name: cm1-config
data:
  db_host: "172.25.254.250"
  db_port: "3306"

---
apiVersion: v1
kind: Pod
metadata:
  name: pod1
spec:
  containers:
    - name: pod1
      image: busybox
      command: ["/bin/sh", "-c", "cat /config/db_host"]
      volumeMounts:
      - name: config-volume
        mountPath: /config
  volumes:
    - name: config-volume
      configMap:
        name: cm1-config
  restartPolicy: Never
[root@server2 cm]# kubectl apply -f cm1.yml 
configmap/cm1-config created
pod/pod1 created
[root@server2 cm]# kubectl logs pod1 
172.25.254.250 

cm1-config里面有两对键值,其中就有db_host
kubernetes存储(一)——ConfigMap配置、管理、应用+热更新_第7张图片
查看输出信息

kubernetes存储(一)——ConfigMap配置、管理、应用+热更新_第8张图片

[root@server2 cm]# vim cm1.yml 
apiVersion: v1
kind: ConfigMap
metadata:
  name: cm1-config
data:
  db_host: "172.25.254.250"
  db_port: "3306"

---
apiVersion: v1
kind: Pod
metadata:
  name: pod1
spec:
  containers:
    - name: pod1
      image: nginx
      volumeMounts:
      - name: config-volume
        mountPath: /config
  volumes:
    - name: config-volume
      configMap:
        name: cm1-config

四、configmap热更新

看似会自动更新,但是pod容器并没有去读取更新信息
[root@server2 cm]# kubectl edit cm cm1-config  编辑cm1-config

kubernetes存储(一)——ConfigMap配置、管理、应用+热更新_第9张图片

[root@server2 cm]# kubectl exec  -it pod1 -- bash

kubernetes存储(一)——ConfigMap配置、管理、应用+热更新_第10张图片

[root@server2 cm]# kubectl exec pod1 -- cat /config/db_host
172.25.254.200
[root@server2 cm]#  kubectl exec pod1 -- cat /config/db_port
3309 

实现滚动更新,使用Deployment控制器

[root@server2 cm]# cat cm1.yml 
apiVersion: v1
kind: ConfigMap
metadata:
  name: cm1-config
data:
  db_host: "172.25.254.250"
  db_port: "3306"

---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: my-nginx
spec:
  replicas: 1
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
        - name: nginx
          image: nginx
          ports:
          volumeMounts:
          - name: config-volume
            mountPath: /etc/nginx/conf.d/  指定挂载目录
      volumes:
        - name: config-volume
          configMap:
            name: nginx-config     创建新的cm
创建cm
[root@server2 cm]# kubectl create configmap nginx-config --from-file=service.conf 
configmap/nginx-config created
[root@server2 cm]# kubectl get cm
NAME           DATA   AGE
my-config      2      3h35m
my-config-2    1      3h26m
my-config-3    2      3h16m
nginx-config   1      1s  成功创建

kubernetes存储(一)——ConfigMap配置、管理、应用+热更新_第11张图片

kubernetes存储(一)——ConfigMap配置、管理、应用+热更新_第12张图片
查看更改的内容已经生效
kubernetes存储(一)——ConfigMap配置、管理、应用+热更新_第13张图片
接下来更改端口

[root@server2 cm]# kubectl edit cm nginx-config 

kubernetes存储(一)——ConfigMap配置、管理、应用+热更新_第14张图片
端口已经更改
kubernetes存储(一)——ConfigMap配置、管理、应用+热更新_第15张图片
configmap热更新后,并不会触发相关Pod的滚动更新,需要手动触发
kubernetes存储(一)——ConfigMap配置、管理、应用+热更新_第16张图片
手动触发

[root@server2 cm]#  kubectl patch deployments.apps my-nginx --patch '{"spec": {"template": {"metadata": {"annotations": {"version/config": "2020072"}}}}}'
deployment.apps/my-nginx patched

kubernetes存储(一)——ConfigMap配置、管理、应用+热更新_第17张图片

你可能感兴趣的:(k8s)