kubernetes资源对象--ConfigMap
2018-02-01 00:00
399 查看
下文基于kubernetes 1.5.2版本编写
ConfigMap是存储通用的配置变量的,类似于配置文件,使用户可以将分布式系统中用于不同模块的环境变量统一到一个对象中管理;而它与配置文件的区别在于它是存在集群的“环境”中的,并且支持K8S集群中所有通用的操作调用方式。
从数据角度来看,ConfigMap的类型只是键值组,用于存储被Pod或者其他资源对象(如RC)访问的信息。这与secret的设计理念有异曲同工之妙,主要区别在于ConfigMap通常不用于存储敏感信息,而只存储简单的文本信息。
ConfigMap可以保存环境变量的属性,也可以保存配置文件。
创建pod时,对configmap进行绑定,pod内的应用可以直接引用ConfigMap的配置。相当于configmap为应用/运行环境封装配置。
pod使用ConfigMap,通常用于:设置环境变量的值、设置命令行参数、创建配置文件。
–from-file表示来自文件,直接把文件内容写入configmap中,可以为目录也可以为文件,如果是文件的话,可以使用db_config_file=database.conf来修改key值
–from-literal表示使用键值对配置
data就是配置变量:
PWD和user两行就是两个环境变量属性
mysql.config : |-就是配置文件,下面的内容是配置文件mysql.config内容
当ConfigMap以数据卷的形式挂载进Pod时,更新ConfigMap(或删掉重建ConfigMap),Pod内挂载的配置信息会热更新,但使用环境变量方式加载到pod,则不会自动更新。
原理
很多生产环境中的应用程序配置较为复杂,可能需要多个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 lykops-config --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使用,第一种是环境变量或参数,第二种是文件挂载。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,则不会自动更新。
相关文章推荐
- kubernetes资源对象--ConfigMap
- [置顶] kubernetes资源对象--ConfigMap
- kubernetes资源对象--limitranges
- [置顶] kubernetes--优雅删除资源对象
- kubernetes DaemonSet资源对象
- kubernetes资源对象--Horizontal Pod Autoscaling(HPA)
- kubernetes资源对象--ingress
- [置顶] kubernetes创建资源对象yaml文件例子--rc
- kubernetes资源对象--deployment
- [置顶] kubernetes资源对象--deployment
- kubernetes资源对象--持久化存储Persistent Volume和Persistent Volume Claim
- kubernetes资源对象--DaemonSet
- kubernetes资源对象--RC和RS
- [置顶] kubernetes资源对象--PetSets/StatefulSet
- kubernetes资源对象--ResourceQuotas
- kubernetes资源对象--pod和job
- [置顶] kubernetes资源对象--Volume
- [置顶] kubernetes创建资源对象yaml文件例子--pod
- kubernetes资源对象--PetSets/StatefulSet
- [置顶] kubernetes资源对象--RC和RS