• [置顶] kubernetes资源对象--ConfigMap


    原理

    很多生产环境中的应用程序配置较为复杂,可能需要多个config文件、命令行参数和环境变量的组合。使用容器部署时,把配置应该从应用程序镜像中解耦出来,以保证镜像的可移植性。尽管Secret允许类似于验证信息和秘钥等信息从应用中解耦出来,但在K8S1.2前并没有为了普通的或者非secret配置而存在的对象。在K8S1.2后引入ConfigMap来处理这种类型的配置数据。

    ConfigMap是存储通用的配置变量的,类似于配置文件,使用户可以将分布式系统中用于不同模块的环境变量统一到一个对象中管理;而它与配置文件的区别在于它是存在集群的“环境”中的,并且支持K8S集群中所有通用的操作调用方式。

    从数据角度来看,ConfigMap的类型只是键值组,用于存储被Pod或者其他资源对象(如RC)访问的信息。这与secret的设计理念有异曲同工之妙,主要区别在于ConfigMap通常不用于存储敏感信息,而只存储简单的文本信息。

    ConfigMap可以保存环境变量的属性,也可以保存配置文件。

    创建pod时,对configmap进行绑定,pod内的应用可以直接引用ConfigMap的配置。相当于configmap为应用/运行环境封装配置。

    pod使用ConfigMap,通常用于:设置环境变量的值、设置命令行参数、创建配置文件。

    创建configmap

    命令行

    kubectl create configmap test-a --from-file=db_config_file=database.conf --from-file=ver.conf --from-literal=username=test --from-literal=hostname=localhost
    

    –from-file表示来自文件,直接把文件内容写入configmap中,可以为目录也可以为文件,如果是文件的话,可以使用db_config_file=database.conf来修改key值
    –from-literal表示使用键值对配置

    yaml文件

    kubectl delete -f lykops-config.yaml
    cat << EOF > lykops-config.yaml
    kind: ConfigMap
    apiVersion: v1
    metadata:
      name: lykops-config
      namespace: default  
      labels:
        software: apache
        project: lykops
        app: configmap
        version: v1
    data:
      PWD: /
      user: lykops
      mysql.config : |-
        username: lykops
        host: localhost
        port: 3306
    EOF
    kubectl create -f lykops-config.yaml
    

    data就是配置变量:
    PWD和user两行就是两个环境变量属性
    mysql.config : |-就是配置文件,下面的内容是配置文件mysql.config内容

    使用ConfigMap

    两种方式让pod使用,第一种是环境变量或参数,第二种是文件挂载。

    kubectl delete -f lykops-cm-pod.yaml
    cat << EOF > lykops-cm-pod.yaml
    apiVersion: v1 
    kind: Pod 
    metadata:
      name: lykops-cm-pod
      labels:
        project: lykops
        app: lykops-cm
        version: v1      
    spec:
      containers:
      - name: lykops-cm-pod
        image: web:apache 
        command: ['sh',/etc/run.sh] 
        env:
        - name: SPECIAL_USER
          valueFrom:
            configMapKeyRef:
              name: lykops-config
              key: username
        resources: 
          requests: 
            cpu: 0.01 
            memory: 8Mi 
          limits: 
            cpu: 0.1
            memory: 16Mi
        volumeMounts:
        - name: config-volume
          mountPath: /data/
      volumes:
        - name: config-volume
          configMap:
            name: lykops-config
    EOF
    kubectl create -f lykops-cm-pod.yaml
    

    当ConfigMap以数据卷的形式挂载进Pod时,更新ConfigMap(或删掉重建ConfigMap),Pod内挂载的配置信息会热更新,但使用环境变量方式加载到pod,则不会自动更新。

  • 相关阅读:
    Permutation Test 置换检验
    计算机会议排名等级
    国际顶级计算机会议
    机器学习中的范数规则化 L0、L1与L2范数 核范数与规则项参数选择
    岭回归(Ridge Regression)
    popupWindow使用timePicker时点击出现闪屏问题的解决办法
    Java:单例模式的七种写法
    JSONObject遍历获取键值方法合并两个JSONObject
    解决android studio上“com.android.dex.DexIndexOverflowException: method ID not in [0, 0xffff]: 65935”问题
    解决同时共用MOB公司的shareSDK和SMSSDK的冲突问题
  • 原文地址:https://www.cnblogs.com/lykops/p/7419934.html
Copyright © 2020-2023  润新知