K8s——配置管理(1)

目录

基本概念

‌核心特性‌

‌核心原理‌

‌核心使用方式‌

[1. ‌环境变量注入‌](#1. ‌环境变量注入‌)

[2. ‌挂载为文件‌](#2. ‌挂载为文件‌)

[3. ‌引用单个文件](#3. ‌引用单个文件)

[4. ‌作为命令行参数‌](#4. ‌作为命令行参数‌)

[‌ConfigMap 的意义‌](#‌ConfigMap 的意义‌)

‌最佳实践与注意事项‌

‌示例场景‌

总结


基本概念

ConfigMap 是 Kubernetes 中用于存储‌非敏感配置数据‌(如环境变量、配置文件、命令行参数等)的 API 对象。它将配置与容器镜像解耦,实现应用的灵活配置管理。


核心特性
  1. 键值对存储

    • 数据以 key: value 形式存储(支持纯文本、JSON、XML等)。
    • 示例:log_level: debug 或整个配置文件内容。
  2. 多数据来源

    支持从多种方式创建:

    • 文件 ‌:kubectl create configmap <name> --from-file=<file-path>
    • 目录‌:自动合并目录内所有文件。
    • 字面值 ‌:kubectl create configmap <name> --from-literal=key=value
  3. 命名空间隔离

    ConfigMap 属于特定命名空间(Namespace),仅同命名空间的 Pod 可引用。

  4. 动态更新支持

    • 挂载为文件时‌:更新 ConfigMap 后,Kubernetes 自动同步到已挂载的 Pod(需应用支持重载)。
    • 环境变量注入时 ‌:‌不支持‌动态更新,需重启 Pod。
  5. 大小限制

    单个 ConfigMap 最大 ‌1 MiB‌(受 etcd 限制)。


核心原理
  1. 存储机制

    • ConfigMap 数据存储在 Kubernetes 的 ‌etcd‌ 数据库中。
    • 通过 API Server 提供创建/读取/更新接口。
  2. 数据注入到 Pod

    • 环境变量‌:直接注入到容器环境。
    • 文件挂载‌:将 ConfigMap 内容挂载为容器内的文件或目录。
    • 命令行参数 ‌:通过 $(KEY) 语法引用。
  3. 更新传播

    • 文件挂载‌:kubelet 定期检查更新(默认同步周期约 1 分钟),将新内容写入容器文件系统。
    • 环境变量‌:仅 Pod 启动时注入,运行时不可变。

核心使用方式
1. ‌环境变量注入
复制代码
env:
 - name: LOG_LEVEL
   valueFrom:
     configMapKeyRef:
       name: app-config # ConfigMap 名称
       key: log_level # 键名 
2. ‌挂载为文件
复制代码
volumes:
 - name: config-volume
   configMap:
     name: app-config # 整个 ConfigMap 挂载为目录 

volumeMounts:
 - name: config-volume
   mountPath: /etc/config # 容器内挂载路径 
3. ‌引用单个文件
复制代码
volumes:
 - name: config-volume
   configMap:
     name: app-config
     items:
       - key: "nginx.conf" # ConfigMap 中的键
         path: "nginx.conf" # 容器内文件名 

volumeMounts:
 - name: config-volume
   mountPath: /etc/nginx/conf.d 
4. ‌作为命令行参数
复制代码
args:
 - "--db-host=$(DB_HOST)" 
env:
 - name: DB_HOST
   valueFrom:
     configMapKeyRef:
       name: app-config
       key: db_host 

ConfigMap 的意义
  1. 解耦配置与代码

    • 无需重构镜像即可修改配置(如切换开发/生产环境)。
    • 提升镜像复用性和安全性(避免硬编码敏感路径)。
  2. 统一配置管理

    • 集中管理多环境配置(通过不同 ConfigMap 区分)。
    • 与 CI/CD 流水线集成,实现配置版本化。
  3. 动态配置更新

    • 文件挂载方式支持‌不重启容器‌更新配置(适合 Nginx、微服务等场景)。
  4. 降低运维复杂度

    • 替代传统方案(如手动修改容器内文件或重建镜像)。

最佳实践与注意事项
  1. 敏感数据用 Secret

    ConfigMap ‌明文存储数据‌,敏感信息(密码、密钥)应使用 Secret。

  2. 设置默认值与可选引用

    复制代码
    envFrom:
     - configMapRef:
         name: app-config
         optional: true # 即使 ConfigMap 不存在,Pod 也能启动 
  3. 文件更新策略

    • 应用需监听文件变化(如 inotify)或定期重载配置。
    • 避免符号链接:挂载 ConfigMap 会覆盖整个目录。
  4. 资源命名规范

    使用明确名称(如 redis-config),避免通用名引起冲突。


示例场景

场景‌:为 Nginx 配置动态更新

  1. 创建 ConfigMap:

    复制代码
    kubectl create configmap nginx-conf --from-file=default.conf 
  2. Pod 挂载配置:

    复制代码
    volumeMounts:
     - name: nginx-config
       mountPath: /etc/nginx/conf.d 
    volumes:
     - name: nginx-config
       configMap:
         name: nginx-conf 
  3. 修改配置后更新 ConfigMap:

    复制代码
    kubectl create configmap nginx-conf --from-file=default.conf --dry-run=client -o yaml | kubectl replace -f - 

    Nginx 会自动加载新配置(需配置 nginx -s reload)。


总结

ConfigMap 是 Kubernetes 配置管理的基石‌,通过分离配置与镜像:

  • 提升应用可移植性和可维护性。
  • 支持动态更新(文件挂载)。
  • 规避明文存储敏感数据。
  • ️ 注意环境变量需重启生效。
相关推荐
坐望云起1 分钟前
Hyper-V + Centos stream 9 搭建K8s集群(一)
linux·kubernetes·centos
麦兜*2 小时前
Spring Boot 整合量子密钥分发(QKD)实验方案
java·jvm·spring boot·后端·spring·spring cloud·maven
码破苍穹ovo3 小时前
堆----1.数组中的第K个最大元素
java·数据结构·算法·排序算法
2301_793086873 小时前
JVM 01 运行区域
java·开发语言
崎岖Qiu3 小时前
【JVM篇13】:兼顾吞吐量和低停顿的G1垃圾回收器
java·jvm·后端·面试
久念祈4 小时前
C++ - 仿 RabbitMQ 实现消息队列--服务端核心模块实现(五)
java·rabbitmq·java-rabbitmq
超级晒盐人6 小时前
用落霞归雁的思维框架推导少林寺用什么数据库?
java·python·系统架构·学习方法·教育电商
岁忧6 小时前
(LeetCode 面试经典 150 题) 138. 随机链表的复制 (哈希表)
java·c++·leetcode·链表·面试·go
鹦鹉0076 小时前
IO流中的字节流
java·开发语言·后端
潘多编程6 小时前
云原生三剑客:Kubernetes + Docker + Spring Cloud 实战指南与深度整合
docker·云原生·kubernetes