zoukankan      html  css  js  c++  java
  • Kubernetes---存储--configMap

    configMap在k8s中,专门用来存储配置文件。

    Secret,有一些需要加密的信息,例如密钥、用户名密码信息在Secret中可以被加密,是k8s中加密的解决方案【base64】。

    Volume,用于赋予k8s中pod共享存储卷的能力,例如可以通过nfs共享,本地磁盘目录共享等等。

    Persistent Volume,简称PV【持久卷】,还包含一个PVC,通过服务进行持久卷的构建。

    ⒈描述

      ConfigMap功能在 Kubernetes1.2版本中引入,许多应用程序会从配置文件、命令行参数或环境变量中读取配置信息。ConfigMap API给我们提供了向容器中注入配置信息的机制,ConfigMap可以被用来保存单个属性,也可以用来保存整个配置文件或者JSON 二进制大对象。

    ⒉引用  -  配置文件注册中心

      在集群中有一个配置文件注册中心,集群中的节点向配置中心索要属于自身的配置,配置中心根据各节点的主机名或ip地址进行分发配置。

    ⒊作用

      k8s创建configMap,pod去引用,来达到类似于配置文件注册中心的效果

    ⒋创建方式【三种方式】

      1.使用目录创建

        1.查看目录文件清单

    ls docs/user-guide/configmap/kubectl/ 

        2.查看文件内容

    cat docs/user-guide/configmap/kubectl/game.properties 

        3.使用目录创建configMap

    kubectl create configmap game-config --from-file=docs/user-guide/configmap/kubectl

        *  game-config指创建的configMap的名称

          --from-file 指定该目录下的所有文件都会被用在ConfigMap里面创建一个键值对,键的名字就是文件名,值就是对应文件的内容【K/V结构】

      2.使用文件创建

        从单一文件创建configMap,只要指定为一个文件就可以从单个文件中创建ConfigMap

        和目录创建configMap的区别就是  --from-file  一个指定到了目录,一个指定到了单一的文件

        1.创建

    kubectl create configmap game-config-2 --from-file=docs/user- guide/configmap/kubectl/game.properties 

      3.使用字面值创建

        使用文字值创建,利用 --from-literal 参数传递配置信息,该参数可以使用多次,格式如下

        1.创建

    kubectl create configmap special-config --from-literal=special. how=very --from-literal=special.type=charm

    ⒌相关命令

      1.查看所有的configMap

    kubectl get cm

      2.查看指定的configMap的详细信息

    kubectl get cm game-config -o yaml
    kubectl describe cm game-config

    ⒍Pod中使用ConfigMap

       1.使用ConfigMap来替代环境变量

        1.创建两个ConfigMap

    apiVersion: v1 
    kind: ConfigMap 
    metadata:
      name: special-config 
      namespace: default 
    data:
      special.how: very 
      special.type: charm 
    apiVersion: v1 
    kind: ConfigMap 
    metadata:
      name: env-config 
      namespace: default 
    data:
      log_level: INFO

        2.创建Pod并以ConfigMap作为环境变量

    apiVersion: v1 
    kind: Pod 
    metadata:
      name: dapi-test-pod 
    spec:
      containers:
        - name: test-container 
          image: hub.coreqi.cn/library/myapp:v1 
          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 
        envFrom:
          - configMapRef:
            name: env-config 
      restartPolicy: Never

       2.用ConfigMap设置命令行参数

        1.创建ConfigMap

    apiVersion: v1 
    kind: ConfigMap 
    metadata:
      name: special-config 
      namespace: default 
    data:
      special.how: very 
      special.type: charm

        2.创建Pod

    apiVersion: v1 
    kind: Pod 
    metadata:
      name: dapi-test-pod 
    spec:
      containers: 
        - name: test-container 
          image: hub.coreqi.cn/library/myapp:v1 
          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

      3.通过数据卷插件使用ConfigMap

        1.创建ConfigMap

    apiVersion: v1 
    kind: ConfigMap 
    metadata:
      name: special-config 
      namespace: default 
    data:
      special.how: very 
      special.type: charm

        在数据卷里面使用这个ConfigMap,有不同的选项。最基本的就是将文件填入数据卷,在这个文件中,键就是文件名,键值就是文件内容

        2.新建Pod

    apiVersion: v1 
    kind: Pod 
    metadata:
      name: dapi-test-pod 
    spec:
      containers:
        - name: test-container 
          image: hub.coreqi.cn/library/myapp:v1 
          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

    ⒎ConfigMap的热更新

       1.新建ConfigMap

    apiVersion: v1 
    kind: ConfigMap 
    metadata:
      name: log-config 
      namespace: default 
    data:
      log_level: INFO

      2.新建Deployment控制器

    apiVersion: extensions/v1beta1 
    kind: Deployment 
    metadata:
      name: my-nginx 
    spec:
      replicas: 1 
      template:
        metadata:
          labels:
            run: my-nginx 
        spec:
          containers:
          - name: my-nginx 
            image: hub.coreqi.cn/library/myapp:v1 
            ports:
            - containerPort: 80 
            volumeMounts:
            - name: config-volume 
              mountPath: /etc/config 
          volumes:
            - name: config-volume 
              configMap:
                name: log-config 

      3.查看数据卷中ConfigMap的值

    kubectl exec `kubectl get pods -l run=my-nginx -o=name|cut -d "/" -f2` cat /etc/config/log_level

      4.修改ConfigMap的值【使用该命令打开yaml文件进行修改】

    kubectl edit configmap log-config

      5.修改Configmap的值后等待大约10秒钟的时候,再次查看环境变量的值

    kubectl exec `kubectl get pods -l run=my-nginx -o=name|cut -d "/" -f2` cat /etc/config/log_level

      **ConfigMap更新后,Pod并不会重载这个文件,更新 ConfigMap目前并不会触发相关Pod 的滚动更新,可以通过修改 pod annotations 的方式强制触发滚动更新

      6.ConfigMap更新后滚动更新 Pod

    kubectl patch deployment my-nginx --patch '{"spec": {"template": {"metadata": {"annotations": {"version/config": "20200430"}}}}}'  
      这个例子中我们在 .spec.template.metadata.annotations 中添加 version/config,每次通过修改 version/config 来触发滚动更新
     
       !!! 更新 ConfigMap后:
        1.使用该ConfigMap挂载的Env不会同步更新
        2.使用该ConfigMap挂载的Volume中的数据需要一段时间(实测大概10秒)才能同步更新

  • 相关阅读:
    Mac连接远程Linux管理文件(samba)
    centos6 防火墙iptables操作整理
    安装postgresql
    linux CentOS6.5 yum安装mysql 5.6
    centos--git搭建之Gogs安装
    查看mysql 默认端口号和修改端口号
    centos之mysql安装配置使用
    流媒体服务器SRS部署
    redis配置文件参数说明
    redis 安装
  • 原文地址:https://www.cnblogs.com/fanqisoft/p/12806590.html
Copyright © 2011-2022 走看看