如何在Kubernetes集群上部署第一个pod?

时间:2021-10-16 11:03:49

如何在Kubernetes集群上部署第一个pod?

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文件。使用以下命令在系统中创建一个新目录:

  1. mkdir my-first-pod
  2. cd my-first-pod/

在进行下一步之前,请验证集群的状态。

要检查集群中可用的节点并检查“kubectl”的版本,请使用以下命令。

  1. sudo kubectl get nodes
  2. sudo kubectl version

使用以下命令列出默认命名空间中的pod。由于这是我们在集群中的第一个pod,您不会看到默认命名空间中的任何pod。

  1. sudo kubectl get pods

一旦集群中有了可用的节点,您可以准备创建第一个pod了。

创建文件“my-first-pod.yml”,附有以下代码段:

  1. vim my-first-pod.yml
  2. ---
  3. apiVersion: v1
  4. kind: Pod
  5. metadata:
  6. name: myfirstpod
  7. labels:
  8. app: web
  9. spec:
  10. containers:
  11. - name: myfirstcontainer
  12. image: nginx
  13. ports:
  14. - containerPort: 80

其中

  • apiVersion:APIVersion定义了对象的这个表示的版本模式。
  • kind:您想创建的对象的类别。这里它是pod,因为我们在创建的是pod。
  • name:名称在命名空间中是独特的。
  • labels:可用于组织和分类对象的字符串键和值的映射。
  • spec:pod的预期行为的规范。

现在您可以准备使用以下命令创建pod了。

  1. sudo kubectl apply -f my-first-pod.yml

您可以使用以下命令获取pod的细节。

  1. sudo kubectl get pods

为证实Pod是否果真在运行中,运行以下命令。这在我们的pod里面运行命令(注意:这类似运行docker exec。)

  1. sudo kubectl exec myfirstpod — service nginx status

如果您不再需要pod,可使用“kubectl delete command”删除它。

  1. sudo kubectl delete pods myfirstpod

最后要证实pod是否已被删除,使用以下命令:

  1. 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