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

译文
云计算
我们在本文中将看到如何在Kubernetes集群上创建我们的第一个Pod,以及为Nginx创建pod的步骤。

[[437979]]

【51CTO.com快译】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】

 

责任编辑:华轩 来源: 51CTO
相关推荐

2021-09-02 08:02:50

深度学习Kubernetes集群管理

2020-08-25 07:48:17

Kubernetes集群系统

2021-12-03 23:21:45

数据库MySQLKubernetes

2021-07-20 08:00:00

集群Elasticsear工具

2017-10-13 15:59:24

iPhone机器学习iOS

2024-03-18 09:50:18

Selenium元素Python

2021-11-02 08:00:00

机器学习API技术

2022-02-17 11:08:00

KubernetesMySQL运维

2021-03-17 10:05:42

KubernetesRedis数据库

2015-10-10 15:56:22

OpenShiftNodeJS部署PaaS

2021-08-10 07:27:42

Elasticsear集群开源

2015-10-23 17:29:24

AtomicOpenStack 应用部署

2022-11-01 07:23:55

Dockernetcore程序

2010-07-30 14:50:38

Flex项目

2021-06-15 09:33:44

Kubernetes Prometheus 容器

2021-05-17 14:51:23

链码区块链网络

2021-09-02 05:37:22

Containerd Kubernetes 容器

2020-12-04 18:44:29

KubernetesHTTPS Wordpress

2018-10-15 10:10:41

Linux内核补丁

2021-04-07 13:38:27

Django项目视图
点赞
收藏

51CTO技术栈公众号