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 配置管理的基石‌,通过分离配置与镜像:

  • 提升应用可移植性和可维护性。
  • 支持动态更新(文件挂载)。
  • 规避明文存储敏感数据。
  • ️ 注意环境变量需重启生效。
相关推荐
zizisuo42 分钟前
解决在使用Lombok时maven install 找不到符号的问题
java·数据库·maven
笨蛋少年派1 小时前
JAVA基础语法
java·开发语言
Haooog1 小时前
654.最大二叉树(二叉树算法)
java·数据结构·算法·leetcode·二叉树
我真的是大笨蛋1 小时前
依赖倒置原则(DIP)
java·设计模式·性能优化·依赖倒置原则·设计规范
东方芷兰2 小时前
JavaWeb 课堂笔记 —— 20 SpringBootWeb案例 配置文件
java·开发语言·笔记·算法·log4j·intellij-idea·lua
Roye_ack2 小时前
【项目实战 Day9】springboot + vue 苍穹外卖系统(用户端订单模块 + 商家端订单管理模块 完结)
java·vue.js·spring boot·后端·mybatis
人间有清欢2 小时前
java数据权限过滤
java·mybatis·权限控制·数据过滤
A阳俊yi2 小时前
Spring——声明式事务
java·数据库·spring
我要精通C++2 小时前
lua虚拟机的垃圾回收机制
java·开发语言
22jimmy3 小时前
MyBatis动态sql
java·开发语言·mybatis