Kubernetes 可以帮你编排运行有大量容器的软件。Kubernetes 不仅提供工具来管理(或者说 编排)运行的容器,还帮助这些容器根据需要进行扩展。有了 Kubernetes 作为你的中央控制面板control panel(或称 控制平面control plane),你需要一种方式来管理 Kubernetes,而这项工作的工具就是 kubectl。kubectl命令让你控制、维护、分析和排查 Kubernetes 集群的故障。与许多使用ctl(“控制”的缩写)后缀的工具一样,如systemctl和sysctl,kubectl拥有大量的功能和任务权限,所以如果你正在运行 Kubernetes,你肯定会经常使用它。它是一个拥有众多选项的命令,所以下面是kubectl中简单易用的五个常见任务。
1、列出并描述资源
按照设计,容器往往会成倍增加。在某些条件下,它们可以快速增加。如果你只能通过 podman ps或docker ps来查看正在运行的容器,这可能会让你不知所措。通过kubectl get和kubectl describe,你可以列出正在运行的吊舱pod以及它们正在处理的容器信息。更重要的是,你可以通过使用--namespace或name或--selector等选项,只列出所需信息。
get子命令不仅仅对吊舱和容器有用。它也有关于节点、命名空间、发布、服务和副本的信息。
2、创建资源
如果你只通过类似 OpenShift、OKD 或 Kubernetes 提供的 Web 用户界面(UI)创建过发布,但你想从 Linux 终端控制你的集群,那么可以使用 kubectl create。kubectl create命令并不只是实例化一个新的应用发布。Kubernetes 中还有很多其他组件可以创建,比如服务、配额和计划任务。
Kubernetes 中的计划任务可以创建一个临时的吊舱,用来在你选择的时间表上执行一些任务。它们并不难设置。下面是一个计划任务,让一个 BusyBox 镜像每分钟打印 “hello world”。
$ kubectl create cronjob \
hello-world \
--image=busybox \
--schedule="*/1 * * * *" -- echo "hello world"
3、编辑文件
Kubernetes 中的对象都有相应的配置文件,但在文件系统中查找相应的文件较为麻烦。有了 kubectl edit,你可以把注意力放在对象上,而不是定义文件上。你可以通过kubectl找到并打开文件(通过KUBE_EDITOR环境变量,你可以设置成你喜欢的编辑器)。
$ KUBE_EDITOR=emacs \
kubectl edit cronjob/hello-world
4、容器之间的传输文件
初次接触容器的人往往对无法直接访问的共享系统的概念感到困惑。他们可能会在容器引擎或 kubectl中了解到exec选项,但当他们不能从容器中提取文件或将文件放入容器中时,容器仍然会显得不透明。使用kubectl cp命令,你可以把容器当做远程服务器,使主机和容器之间文件传输如 SSH 命令一样简单:
$ kubectl cp foo my-pod:/tmp
5、应用变更
对 Kubernetes 对象进行修改,可以通过 kubectl apply命令完成。你所要做的就是将该命令指向一个配置文件:
$ kubectl apply -f ./mypod.json
类似于运行 Ansible 剧本或 Bash 脚本,apply使得快速“导入”设置到运行中的 Kubernetes 实例很容易。例如,GitOps 工具ArgoCD由于apply子命令,安装起来出奇地简单:
$ kubectl create namespace argocd
$ kubectl apply -n argocd \
-f https://raw.githubusercontent.com/argoproj/argo-cd/vx.y.z/manifests/install.yaml
使用 kubectl
Kubectl 是一个强大的工具,由于它是一个终端命令,它可以写成脚本,并能实现用众多 Web UI 无法实现的功能。学习 kubectl是进一步了解 Kubernetes、容器、吊舱以及围绕这些重要的云计算创新技术的一个好方法。下载我们的 kubectl 速查表,以获得快速参考,其中包括命令示例,以帮助你学习,并在为你提供注意细节。
本文地址:https://gpu.xuandashi.com/4952.html,转载请说明来源于:渲大师
声明:本站部分内容来自网络,如无特殊说明或标注,均为本站原创发布。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。分享目的仅供大家学习与参考,不代表本站立场!