【k8s】k8s存储配置之ConfigMap

一、ConfigMap简介

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

典型的使用场景:

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

创建Configmap的方式:

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

如何使用Configmap:

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

二、创建ConfigMap

01_使用字面值创建

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

02_使用文件创建

  • kubectl create configmap my-config-2 --from-file=/etc/resolv.conf
    key的名称是文件名称
    value的值是这个文件的内容
    在这里插入图片描述

03_使用目录创建

  • 创建目录:mkdir -p configMap/test
    cd configMap/
  • 写入测试文件
    cp /etc/resolv.conf test/
    cp /etc/fstab test/
  • 创建kubectl create configmap my-config-3 --from-file=test
    在这里插入图片描述

04_编写yaml文件创建

vim cm1.yml

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

kubectl apply -f cm1.yml
在这里插入图片描述

三、使用ConfigMap

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

vim pod1.yml

apiVersion: v1
kind: Pod
metadata:
  name: pod1
spec:
  containers:
    - name: pod1
      image: 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 #不重启

kubectl apply -f pod1.yml

查看日志:

在这里插入图片描述

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

vim pod2.yml

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

kubectl apply -f pod2.yml
在这里插入图片描述

03_作为volume的方式挂载到pod内

vim pod3.yml

apiVersion: v1
kind: Pod
metadata:
  name: pod3
spec:
  containers:
    - name: pod3
      image: 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

示例1:
在这里插入图片描述示例2:
在这里插入图片描述

04_热更新

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

更新有延迟:

在这里插入图片描述kubectl edit cm cm1-config
在这里插入图片描述

kubectl attach pod3 -it
在这里插入图片描述

  • 设置热更新
    vim default.conf
server {
    listen       8080;
    server_name  _;

    location / {
        root /usr/share/nginx/html;
        index  index.html index.htm;
    }
}

vim 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
  • 使用文件创建cm:设置端口为8080
    kubectl create configmap nginx-config --from-file=default.conf
    在这里插入图片描述
  • 创建pod(部署nginx):查询IP地址,并访问8080端口
    在这里插入图片描述
    在这里插入图片描述在这里插入图片描述
  • 编辑cm配置信息,修改端口为80,cm配置信息成功修改,但容器内部没有同步端口

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

  • 触发滚动更新:端口号成功同步!
    kubectl patch deployments.apps demo --patch '{"spec": {"template": {"metadata": {"annotations": {"version/config": "2021071101"}}}}}'
    在这里插入图片描述
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值