Pod是Kubernetes应用程序的基本执行单元。它是一起部署在同一个主机上的容器组成的集合。Kubernetes集群中的Pod可以通过两种方式来使用:
- 运行单个容器的Pod:这是使用Pod的最流行方式。Kubernetes管理Pod,而不是直接管理容器。
- 运行多个需要协同工作的容器的Pod:在这种模式中,一个Pod可能有多个紧密耦合的容器以共享资源。
如上所述,一个Pod可能有多个容器,因此始终建议尽可能使用单个容器。在单个Pod中组合多个容器是一种相对高级的用例。您应该仅在容器紧密耦合的特定情况下使用该模式。
如果我们部署单个容器,一般可以将“pod”一词换成“container”。Pod实现了诸成员之间的数据共享和联系。
Pod 始终在节点上运行。节点是Kubernetes中的worker机器,可能是虚拟机或物理机,具体取决于集群。每个节点由主节点(Master)管理。一个节点可能有多个Pod,Kubernetes主节点跨集群中的节点自动处理Pod调度。
Pod生命周期的5个阶段
- 等待中:Pod已被Kubernetes系统接受,但一个或多个容器映像尚未创建。这包括调度之前的时间以及通过网络下载映像所花费的时间,这可能需要一段时间。
- 运行中:Pod已绑定到一个节点上,所有容器已创建好。至少有一个容器仍在运行中,或正在启动或重新启动。
- 成功:Pod内所有容器已成功终止,不会重启。
- 失败:Pod中的所有容器已终止,至少一个容器终止失败。也就是说,容器要么以非零状态退出,要么被系统终止。
- 未知:由于某种原因,无法获取Pod的状态,通常是由于与Pod主机联系出错。
前提条件
- AWS帐户(如果还没有帐户,请创建)
- Kubernetes集群(如果您想学习创建Kubernetes集群,请搜索“使用kubeadm在AWS EC2实例Ubuntu 18.04 LTS上创建Kubernetes集群”)。
注意:如果您不想尝试AWS EC2实例,也可以使用虚拟机来创建集群。
我们要做什么?
- 为NginX创建一个Kubernetes Pod,并删除它。
为Nginx创建Kubernetes Pod
为创建我们的第一个Pod,不妨创建一个新目录来创建我们的Object/Pod文件。使用以下命令在系统中创建一个新目录:
- mkdir my-first-pod
- cd my-first-pod/
在进行下一步之前,请验证集群的状态。
要检查集群中可用的节点并检查“kubectl”的版本,请使用以下命令。
- sudo kubectl get nodes
- sudo kubectl version
使用以下命令列出默认命名空间中的pod。由于这是我们在集群中的第一个pod,您不会看到默认命名空间中的任何pod。
- sudo kubectl get pods
一旦集群中有了可用的节点,您可以准备创建第一个pod了。
创建文件“my-first-pod.yml”,附有以下代码段:
- vim my-first-pod.yml
- ---
- apiVersion: v1
- kind: Pod
- metadata:
- name: myfirstpod
- labels:
- app: web
- spec:
- containers:
- - name: myfirstcontainer
- image: nginx
- ports:
- - containerPort: 80
其中
- apiVersion:APIVersion定义了对象的这个表示的版本模式。
- kind:您想创建的对象的类别。这里它是pod,因为我们在创建的是pod。
- name:名称在命名空间中是独特的。
- labels:可用于组织和分类对象的字符串键和值的映射。
- spec:pod的预期行为的规范。
现在您可以准备使用以下命令创建pod了。
- sudo kubectl apply -f my-first-pod.yml
您可以使用以下命令获取pod的细节。
- sudo kubectl get pods
为证实Pod是否果真在运行中,运行以下命令。这在我们的pod里面运行命令(注意:这类似运行docker exec。)
- sudo kubectl exec myfirstpod — service nginx status
如果您不再需要pod,可使用“kubectl delete command”删除它。
- sudo kubectl delete pods myfirstpod
最后要证实pod是否已被删除,使用以下命令:
- sudo kubectl get pods
结语
我们在本文中了解了pod的基本知识及其生命周期的几个阶段。我们看到了在Kubernetes上创建第一个Nginx Pod的几个步骤,还看到了如何可以提取有关Pod的细节。此外,我们还介绍了删除Pod的命令。
原文标题:How to deploy your first pod on a Kubernetes Cluster
【51CTO译稿,合作站点转载请注明原文译者和出处为51CTO.com】
原文链接:https://cloud.51cto.com/art/202112/693330.htm