`
lykops
  • 浏览: 86252 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
文章分类
社区版块
存档分类
最新评论

kubernetes资源对象--ConfigMap

 
阅读更多

下文基于kubernetes 1.5.2版本编写

原理

很多生产环境中的应用程序配置较为复杂,可能需要多个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,则不会自动更新。

<script type="text/javascript"> $(function () { $('pre.prettyprint code').each(function () { var lines = $(this).text().split('\n').length; var $numbering = $('<ul/>').addClass('pre-numbering').hide(); $(this).addClass('has-numbering').parent().append($numbering); for (i = 1; i <= lines; i++) { $numbering.append($('<li/>').text(i)); }; $numbering.fadeIn(1700); }); }); </script>
分享到:
评论

相关推荐

    kubernetes-server-linux-amd64.tar.gz

    1. **API服务器**:它是集群的中央数据存储和通信中心,处理所有资源对象的增删改查操作,并通过etcd存储集群状态。 2. **控制器管理器**:负责运行一系列协调控制器,如ReplicaSet控制器保证Pod副本数量的正确性,...

    kubernetes-client-linux-amd64.tar.gz

    在 Linux 环境下,用户可以利用这个客户端执行如创建、查询、更新和删除 Kubernetes 对象(如 Pod、Service、Deployment、ConfigMap 等)的操作。 压缩包子文件 "kubernetes" 可能包含了以下内容: 1. `kubectl`:...

    kubernetes-handbook-jimmysong-v1.3

    - **存储解决方案**:Secret、ConfigMap、Volume、Persistent Volume(PV)以及StorageClass等资源对象的配置和管理。 - **本地持久化存储**:如何在Kubernetes集群内配置和使用本地存储。 ### 安全性 - **集群安全...

    kubernetes-server-linux-amd64-v1.17.17.tar.gz

    6. **ConfigMap**和**Secrets**:这两种对象用来管理非代码配置数据和敏感信息,如密码、密钥等。 7. **Ingress**:Ingress资源用于定义外部网络到集群内部服务的规则,可以实现基于路径的路由和SSL终止等功能。 8...

    kubernetes-handbook-jimmysong-v1.4-20180903.pdf

    NetworkPolicy允许精细的网络流量控制,Secret和ConfigMap则用于管理敏感信息和配置数据。持久化存储通过Persistent Volume和Storage Class实现,而Local Persistent Storage则支持本地存储资源的使用。 Kubernetes...

    安装 kubernetes 网络组件-Calico

    4. **部署 Calico 控制平面**:使用 `kubectl apply -f` 命令将 YAML 文件应用到集群,这会创建 Calico 的 Deployment、DaemonSet 和 ConfigMap 等资源。 5. **等待 Calico 启动**:在所有 Worker 节点上,Calico ...

    kubernetes-tools-and-scripts

    1. 自动化部署:使用Python脚本可以创建和更新Deployment、Service、ConfigMap等Kubernetes对象。 2. 监控与日志:脚本可以帮助收集Pod的性能指标,或者从容器中提取日志,进行分析和报警。 3. 扩缩容管理:动态调整...

    Kubernetes-component-templates:Kubernetes组件的模板YAML文件

    2. **YAML模板**: 每个YAML文件都是一个或多个Kubernetes对象的定义,如Deployment、Service、Pod、ConfigMap等。这些模板包含了组件的默认设置,例如镜像版本、端口配置、环境变量、资源限制等。通过这些模板,我们...

    kubernetes-yaml-templates:Kubernetes Yaml模板

    YAML(YAML Ain't Markup Language)是Kubernetes用来描述资源对象的主要格式,它是一种轻量级的数据序列化语言,非常适合定义和配置Kubernetes集群中的各种组件。"kubernetes-yaml-templates"是一个集合,包含了...

    kubernetes-dashboard.zip

    你已经有一个名为 "kubernetes-dashboard.zip" 的压缩包,其中包含了一个名为 "kubernetes-dashboard.yaml" 的文件,这是一个 YAML 文件,通常用于定义 Kubernetes 对象,如 Deployment、Service 或 ConfigMap。...

    kubernetes-docs-zh:kubernetes文档的英语翻译

    - API Server:作为整个系统的控制中心,处理所有资源对象的增删改查请求。 - etcd:存储集群的状态信息,是高度可用的键值数据库。 - Scheduler:负责将未调度的Pod分配到合适的Node上。 - Controller Manager...

    k8s-kotlin-dsl,用于kubernetes配置的kotlin dsl.zip

    K8s-Kotlin-DSL项目旨在为Kubernetes提供一种更直观、更易读的配置方式,通过使用Kotlin编程语言的领域特定语言(DSL)来构建Kubernetes资源对象。 1. **Kotlin DSL的优势** - **可读性增强**:相比传统的YAML或...

    Kubernetes资源清单模板

    总结来说,Kubernetes资源清单模板是理解和操作Kubernetes集群的关键工具,它简化了资源创建和管理的过程。了解并熟练使用这些模板,可以帮助我们更高效地部署和维护应用在Kubernetes集群上的运行状态。通过定制和...

    kubernetes-perfect-guide:“ Kubernetes完全ガイド”の付录マニフェストのリポジトリ“ Kubernetes完美指南”样本清单库

    - **ConfigMap**:存储非敏感数据,如配置文件,让应用在Pod中使用。 - **Secret**:安全地存储敏感信息,如密码、密钥等。 - **PersistentVolume/PersistentVolumeClaim**:持久化存储解决方案,确保数据在Pod...

    kubernetes-learning.pdf

    监控 Kubernetes 常⽤资源对象 Grafana 的安装使⽤ AlertManager 的使⽤ Prometheus Operator 的安装 ⾃定义Prometheus Operator 监控项 Prometheus Operator⾼级配置 ⽇志收集 ⽇志收集架构 搭建 EFK ⽇志系统 CI/...

    NGINX Ingress Controller:用于 Kubernetes 的 NGINX 入口控制器-开源

    它围绕 Kubernetes Ingress 资源构建,使用 ConfigMap 来存储 NGINX 配置。 这个 Ingress 控制器的目标是组装一个配置文件(nginx.conf)。 此要求的主要含义是在配置文件发生任何更改后需要重新加载 NGINX。 但...

    kubernetes-zh中文手册

    - **ConfigMap**:用于保存非机密性的配置数据。 - **CronJob**:用于执行定时任务。 - **CustomResourceDefinition**:允许用户自定义资源类型。 - **DaemonSet**:确保所有(或某些)节点上运行一个Pod的副本。 - ...

    ConfigMap实验手册1

    在Kubernetes中,ConfigMap是一种资源对象,它允许你将非秘密的应用程序数据(如配置文件、环境变量或命令行参数)外部化,以便于管理和更新。ConfigMap可以使你的应用程序与具体的部署环境解耦,方便在不同的环境中...

    Python库 | cdktf-cdktf-provider-kubernetes-0.5.77.tar.gz

    使用cdktf-provider-kubernetes,我们可以创建Kubernetes资源,如Deployment、Service、Pod、ConfigMap等,就像创建普通的Python对象一样。例如,通过导入必要的模块,我们可以定义一个Deployment对象,并设置其镜像...

    kubernetes-入门指南

    - 使用`kubectl`命令行工具与Kubernetes API交互,创建和管理资源对象。 - YAML或JSON格式的配置文件定义应用的结构和行为。 - `kubectl apply -f &lt;filename&gt;`命令部署应用,`kubectl get`、`kubectl describe`等...

Global site tag (gtag.js) - Google Analytics