【Linux39-7】k8s存储配置之ConfigMap

1. ConfigMap简介


ConfigMap官方文档

ConfigMap 是一种 API 对象,用来将非机密性的数据保存到键值对中。使用时, Pods 可以将其用作环境变量、命令行参数或者存储卷中的配置文件。

和其他 Kubernetes 对象都有一个 spec, 不同的是,ConfigMap 使用 databinaryData 字段。这些字段能够接收键-值对作为其取值。databinaryData 字段都是可选的。data 字段设计用来保存 UTF-8 字节序列,而 binaryData 则 被设计用来保存二进制数据。


  • Configmap用于保存配置数据,以键值对的形式存储
  • Configmap资源提供了向Pod诸如配置数据的方法
  • 旨在让镜像和配置文件解偶,以便实现镜像的可移植性和可复用性

使用场景:

  • 填充环境变量的值
  • 设置容器内的命令行参数
  • 填充卷的配置文件

创建Configmap的方式:

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

如何使用Configmap:

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

2. 创建ConfigMap


2.1 使用字面值创建


创建:

kubectl create configmap my-config --from-literal=key1=config1 --from-literal=key2=config2
#key为名称,value为内容
表示创建一个名称为key1,内容为config1的Configmap
也可以在命令后接多个–from-literal以创建多个键值对。

在这里插入图片描述

2.2 使用文件创建


kubectl create configmap my-config-2 --from-file=/etc/resolv.conf

# key的名称是文件名称
# value的值是这个文件的内容

在这里插入图片描述

扫描二维码关注公众号,回复: 12678721 查看本文章

2.3 使用目录创建


1.创建目录:
mkdir -p configMap/test
cd configMap/
2.写入测试文件
echo 11111 > test/file1
echo 22222 > test/file2
3.创建
kubectl create configmap my-config-3 --from-file=test

在这里插入图片描述

2.4 编写yaml文件创建


kubectl apply -f cm1.yml

# vim cm1.yml
apiVersion: v1
kind: ConfigMap
metadata: 
  name: cm1-config
data:
  db_host: "192.168.17.250"
  db_port: "3306"

在这里插入图片描述

3. 使用ConfigMap


3.1 通过环境变量的方式直接传递给pod


kubectl apply -f pod1.yml

# vim pod1.yml 
apiVersion: v1
kind: Pod
metadata:
  name: pod1
spec:
  containers:
    - name: pod1
      image: radial/busyboxplus
      command: ["/bin/sh", "-c", "env"]
      env: # 定义环境变量
        - name: key1 #将cm1-config的指定内容db_host赋给pod1的key1
          valueFrom:
            configMapKeyRef:
              name: cm1-config
              key: db_host
        - name: key2 #将cm1-config的指定内容db_port赋给pod1的key2
          valueFrom:
            configMapKeyRef:
              name: cm1-config
              key: db_port
  restartPolicy: Never #不重启

查看日志:

在这里插入图片描述

3.2 通过在pod的命令行下运行的方式


kubectl apply -f pod2.yml

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

在这里插入图片描述

3.3 作为volume的方式挂载到pod内


示例1:

# pod3.yml
apiVersion: v1
kind: Pod
metadata:
  name: pod3
spec:
  containers:
    - name: pod3
      image: radial/busyboxplus
      command: ["/bin/sh","-c","ls -l /config/"]
      # command: ["/bin/sh","-c","cat /config/db_host"]
      volumeMounts:
      - name: config-volume
        mountPath: /config
  volumes:
    - name: config-volume
      configMap:
        name: cm1-config
  restartPolicy: Never

在这里插入图片描述
在这里插入图片描述

示例2:

# pod3.yml 
apiVersion: v1
kind: Pod
metadata:
  name: pod3
spec:
  containers:
    - name: pod3
      image: radial/busyboxplus
      stdin: true
      tty: true
      volumeMounts:
      - name: config-volume
        mountPath: /config
  volumes:
    - name: config-volume
      configMap:
        name: cm1-config

在这里插入图片描述

4. 热更新


  • 修改pod数据,pod不会实时更新,需要等待几秒
  • ConfigMap热更新后,并不会触发pod的滚动更新,需要手动触发
  • 每次通修改version/config来触发pod滚动更新
  • 使用configMap挂载的env环境变量是不会更新的

示例:

# default.conf 
server {
    
    
    listen       8080;
    server_name  _;

    location / {
    
    
        root /usr/share/nginx/html;
        index  index.html index.htm;
    }
}
# demo.yml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: demo
spec:
  replicas: 1
  selector:
    matchLabels:
      app: myapp
  template:
    metadata:
      labels:
        app: myapp
    spec:
      containers:
      - name: myapp
        image: myapp:v1
        volumeMounts:
        - name: config-volume
          mountPath: /etc/nginx/conf.d
      volumes:
        - name: config-volume
          configMap:
            name: nginx-config

1)使用文件创建cm:设置端口为8080

kubectl create configmap nginx-config --from-file=default.conf

在这里插入图片描述

2)创建pod(部署nginx):查询IP地址,并访问8080端口

在这里插入图片描述
在这里插入图片描述

3)编辑cm配置信息,修改端口为80,cm配置信息成功修改,但容器内部没有同步端口

kubectl edit cm nginx-config

在这里插入图片描述

4)触发滚动更新:端口号成功同步!

kubectl patch deployments.apps demo --patch '{"spec": {"template": {"metadata": {"annotations": {"version/config": "2021030301"}}}}}'

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_46069582/article/details/114106644