news 2026/6/3 22:39:38

K8S之创建cm指令create和 apply的区别

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
K8S之创建cm指令create和 apply的区别

这两种命令都是用来创建或更新 ConfigMap 的,但它们的工作原理、适用场景和行为模式有本质区别。简单来说,create --from-file是从现有配置文件直接生成一个 ConfigMap,而apply -f是向 Kubernetes声明并应用一个期望的资源配置状态

下面这张表清晰地展示了两者的核心差异:

特性维度kubectl create cm --from-file(命令式命令)kubectl apply -f(声明式对象配置)
核心理念“做什么”:执行一个具体的创建动作。“要什么”:声明资源的最终期望状态。
配置来源本地文件系统的配置文件(.properties,.txt,.conf等)。YAML/JSON 格式的 Kubernetes 资源定义清单。
操作性质命令式:直接下达创建指令。声明式:系统根据你的描述去确保状态一致。
幂等性非幂等:如果资源已存在,会报错AlreadyExists幂等:可以反复执行,用于创建或更新。
更新方式无法直接更新,通常需要先deletecreate,或使用replace可直接更新:修改 YAML 文件后再次apply即可。
版本控制友好度较低。命令本身不记录,需要额外保存生成命令或使用的源文件。极高。YAML 文件本身就是配置的版本记录。

📝 详细解析与使用场景

1.kubectl create configmap --from-file
这种方式适用于快速从现有的、独立的配置文件(如应用打包目录里的配置文件)生成 ConfigMap。

  • 常见用法

    bash

    # 从单个文件创建,key 默认为文件名 “app.properties” kubectl create cm cube-config --from-file=./config/app.properties # 从单个文件创建,并自定义 key 名 kubectl create cm cube-config --from-file=my-app-config=./config/app.properties # 从一个目录下的所有文件创建 kubectl create cm cube-config --from-file=./config/ # 混合创建:同时来自文件和字面值 kubectl create cm cube-config \ --from-file=./config/app.properties \ --from-literal=environment=production
  • 典型场景:在开发或 CI/CD 流水线中,你有一个现成的application.properties,想直接把它放入集群作为配置使用,这时用--from-file非常快捷。

2.kubectl apply -f
这种方式是Kubernetes 声明式管理的核心。你首先需要编写一个描述 ConfigMap 资源完整状态的 YAML 文件。

  • YAML 文件示例 (correct-cube-config.yaml):

    yaml

    apiVersion: v1 kind: ConfigMap metadata: name: cube-config namespace: default # 可指定命名空间 data: # 方式1:直接嵌入多行文本 (使用 |) app.properties: | server.port=8080 database.host=mysql logging.level=INFO # 方式2:直接定义键值对 environment: production version: "1.0" # 方式3:嵌入另一个文件的单行内容 some-key: this is a single line value
  • 典型操作流程

    bash

    # 1. 首次创建 kubectl apply -f correct-cube-config.yaml # 2. 修改 correct-cube-config.yaml 文件内容后,再次执行以更新 kubectl apply -f correct-cube-config.yaml # 3. 查看 apply 记录的历史配置 kubectl rollout history configmap/cube-config

💡 如何选择与转换

  • 选择建议

    • 对于一次性、临时的、或配置与源码分离管理的情况,create --from-file很方便。

    • 对于生产环境、需要版本控制、持续维护和团队协作的配置,apply -f配合 YAML 文件是唯一推荐的方式。

  • 两者转换:你可以很容易地将一种方式生成的 ConfigMap 转换为另一种方式所需的格式。

    bash

    # 将集群中已有的 `cube-config` 导出为声明式的 YAML 文件,这正是 `apply` 所需的。 kubectl get cm cube-config -o yaml > cube-config.yaml # 将本地配置文件转换为一个用于 `apply` 的 YAML 模板 # 这里利用 `kubectl create` 的 dry-run 和 yaml 输出功能 kubectl create cm cube-config --from-file=./config/app.properties --dry-run=client -o yaml > cube-config-template.yaml

📊 总结与最佳实践

简而言之,create是一个一次性命令,而apply是一个持续管理流程

在现代 Kubernetes 的 GitOps 实践中,几乎总是使用kubectl apply -f(或其背后的工具如kustomize,helm) 配合 YAML 文件。这种方式能将所有基础设施配置代码化,便于审查、回滚和自动化,是实现可靠运维的基石。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/3 15:49:28

33、拼写检查:从Unix原型到awk实现

拼写检查:从Unix原型到awk实现 1. 拼写检查概述 拼写检查是一个有趣且具有挑战性的问题,有超过300篇研究论文和书籍都围绕它展开。在处理文本时,拼写检查能帮助我们发现并纠正错误,提高文本质量。下面我们将从不同角度探讨拼写检查的实现方式。 2. 原始Unix拼写检查原型…

作者头像 李华
网站建设 2026/6/3 5:17:14

38、Shell 可移植性问题与扩展

Shell 可移植性问题与扩展 1. 概述 POSIX 定义的 shell 语言比原始的 V7 Bourne shell 大得多,但比 ksh93 和 bash 这两种最常用的 Bourne shell 扩展版本所实现的语言小得多。如果你要进行利用 shell 语言扩展的重型脚本编写,很可能会使用这两种 shell 中的一种或两种。因…

作者头像 李华
网站建设 2026/6/1 12:58:32

47、Unix系统文件管理与安全指南

Unix系统文件管理与安全指南 1. Unix文件所有权与隐私问题 在Unix系统中,文件权限对于控制文件和目录的读写执行访问至关重要。通过谨慎选择文件权限,用户可以控制谁能够访问自己的文件。 umask命令 :这是访问控制的重要工具,它限制了后续创建的所有文件的权限。通常,用…

作者头像 李华
网站建设 2026/6/3 15:47:37

AI驱动SEO变革:智能优化如何提升搜索可见性与本地流量

在当下的数字化潮流里,搜索引擎优化也就是SEO策略,正历经一场借助人工智能技术推动的深刻蜕变。以往那依赖人工经验的优化办法,由于其效率方面的瓶颈以及策略同质化这一问题,正渐渐被更具智能性、更成体系的AI搜索优化方案给替代。…

作者头像 李华
网站建设 2026/6/3 0:29:05

JAVA打造国际悬赏平台:高效匹配,全球接单

JAVA打造国际悬赏平台:高效匹配与全球接单的技术实现路径一、技术架构:高并发与多端协同的基石后端性能引擎采用 Spring Boot 2.7 MyBatis-Plus 组合,内嵌Tomcat支持每秒10,000并发请求,任务状态同步延迟低于200ms。通过 动态分库…

作者头像 李华
网站建设 2026/6/2 14:04:33

【JavaWeb】HttpServletResponse_设置响应信息相关API

目录设置响应行相关的API设置响应头相关的API设置响应体内容API向客户端响应文件设置响应行相关的API 设置响应头相关的API 由于ContentType和ContentLength比较重要,除了这种设置方式,还提供了单独的api进行设置 设置响应体内容API 获得一个向响应体中…

作者头像 李华