K8S-volume存储之configmap

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了K8S-volume存储之configmap相关的知识,希望对你有一定的参考价值。

参考技术A

ConfigMap顾名思义,是用于保存配置数据的键值对,可以用来保存单个属性,也可以保存配置文件。
ConfigMaps允许你将配置构件与映像内容解耦,以保持容器化应用程序的可移植性。configmap 可以从文件、目录或者 key-value 字符串创建等创建 ConfigMap。也可以通过 kubectl create -f从描述文件创建。可以使用 kubectl create创建命令。创建ConfigMap的方式有4种:

从key-value字符串创建,官方翻译是从字面值中创建ConfigMap。
语法规则

案例

在使用kubectl get获取资源信息的时候,可以通过-o(--output简写形式)指定信息输出的格式,如果 指定的是yaml或者json输出的是资源的完整信息,实际工作中,输出内容过少则得不到我们想要的信息,输 出内容过于详细又不利于快速定位的我们想要找到的内容,其实-o输出格式可以指定为go-template然后 指定一个template,这样我们就可以通过go-template获取我们想要的内容.go-template与 kubernetes无关,它是go语言内置的一种模板引擎.这里不对go-template做过多解释,仅介绍在 kubernetes中获取资源常用的语法,想要获取更多内容,大家可以参考相关资料获取帮助。大家记住是固 定语法即可。

创建一个配置文件:jdbc.properties

语法规则如下:当 --from-file指向一个目录,每个目录中的文件直接用于填充ConfigMap中的 key,key的名称是文件名称,value的值是这个文件的内容。下面的命令读取/data目录下的所有文件
kubectl create configmap cumulx-test --from-file=/data/

kubectl create configmap myjdbcconfigmap --from-file=/data/jdbc.properties

查看configmap详细信息
kubectl describe configmaps myjdbcmap

data/mariadbconfigmap.yml

configmap/mariadbsecret.yml

configmap/mariadb.yml--需要再次整理,加入私服镜像信息
注意修改pod的端口号为3307,service的targetPort端口号为3307

k8sk8s存储配置之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"}}}}}'
    在这里插入图片描述

以上是关于K8S-volume存储之configmap的主要内容,如果未能解决你的问题,请参考以下文章

云存储实现之简单的文件存储

云存储实现之简单的文件存储

zookeeper源码之存储系统

懵懂oracle之存储过程2

MySQL之存储过程

数据存储之文件存储