管理方法
注:
管理Kubernetes对象时,只可以使用一种技术来管理。混合和匹配技术作用在同一对象上将匹配。
管理技术 |
作用于 |
建议的环境 |
支持的写者 |
学习难度 |
指令式命令 |
活跃对象 |
开发项目 |
1+ |
最低 |
指令式对象配置 |
单个文件 |
生产项目 |
1 |
中等 |
声明式对象配置 |
文件目录 |
生产项目 |
1+ |
最高 |
指令式命令
用户可以直接使用kubectl命令在集群内进行操作,是最高效最直接的操作方法,可以直接对使用中的对象进行操作,但无法知道历史配置记录。
#例子
#通过创建 Deployment 对象来运行 nginx 容器的实例:
kubectl create deployment nginx --image nginx
指令式对象配置
在指令式对象配置中,kubectl 命令指定操作(创建,替换等),可选标志和 至少一个文件名。指定的文件必须包含 YAML 或 JSON 格式的对象的完整定义;
kubectl replace -f nginx.yaml
简而言之就是通过yaml配置文件对kubernetes进行管理;
例子
创建配置文件中定义的对象:
kubectl create -f nginx.yaml
删除两个配置文件中定义的对象:
kubectl delete -f nginx.yaml -f redis.yaml
通过覆盖活动配置来更新配置文件中定义的对象:
kubectl replace -f nginx.yaml
声明式对象配置
使用声明式对象配置时,用户对本地存储的对象配置文件进行操作,但是用户 未定义要对该文件执行的操作。
kubectl
会自动检测每个文件的创建、更新和删除操作。 这使得配置可以在目录上工作,根据目录中配置文件对不同的对象执行不同的操作。
说明:
声明式对象配置保留其他编写者所做的修改,即使这些更改并未合并到对象配置文件中。 可以通过使用
patch
API 操作仅写入观察到的差异,而不是使用replace
API 操作来替换整个对象配置来实现。
例子
处理
configs
目录中的所有对象配置文件,创建并更新活跃对象。 可以首先使用diff
子命令查看将要进行的更改,然后在进行应用:
kubectl diff -f configs/
kubectl apply -f configs/
递归处理目录:
kubectl diff -R -f configs/
kubectl apply -R -f configs/
对比
指令式与对象配置相比的优点:
- 命令用单个动词表示。
- 命令仅需一步即可对集群进行更改。
指令式与对象配置相比的缺点:
- 命令不与变更审查流程集成。
- 命令不提供与更改关联的审核跟踪。
- 除了实时内容外,命令不提供记录源。
- 命令不提供用于创建新对象的模板。
指令式对象与指令式命令相比的优点:
- 对象配置可以存储在源控制系统中,比如 Git。
- 对象配置可以与流程集成,例如在推送和审计之前检查更新。
- 对象配置提供了用于创建新对象的模板。
指令式对象与指令式命令相比的缺点:
- 对象配置需要对对象架构有基本的了解。
- 对象配置需要额外的步骤来编写 YAML 文件。
指令式对象与声明式对象配置相比的优点:
- 指令式对象配置行为更加简单易懂。
- 从 Kubernetes 1.5 版本开始,指令对象配置更加成熟。
指令式对象与声明式对象配置相比的缺点:
- 指令式对象配置更适合文件,而非目录。
- 对活动对象的更新必须反映在配置文件中,否则会在下一次替换时丢失。
指令式声明与指令式对象配置相比的优点:
- 对活动对象所做的更改即使未合并到配置文件中,也会被保留下来。
- 声明性对象配置更好地支持对目录进行操作并自动检测每个文件的操作类型(创建,修补,删除)。
指令式声明与指令式对象配置相比的缺点:
- 声明式对象配置难于调试并且出现异常时结果难以理解。
- 使用 diff 产生的部分更新会创建复杂的合并和补丁操作。