社区编辑申请
注册/登录
如何在Kubernetes集群上部署第一个pod? 译文
云计算
我们在本文中将看到如何在Kubernetes集群上创建我们的第一个Pod,以及为Nginx创建pod的步骤。

【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
相关推荐

2020-08-25 07:48:17

Kubernetes集群系统

2020-08-04 07:58:36

Kubernetes集群工具

2022-06-02 14:18:44

kubeadm云原生

2022-07-11 09:46:43

Kubernetes开源Linux

2019-12-06 14:24:58

Kubernetes容器YAML

2020-04-26 11:16:46

KubernetesPodLinux

2021-11-08 07:48:48

2021-06-01 08:00:43

KubernetesCentOS版集群

2020-06-10 09:57:23

Kubernetes日志容器

2021-05-12 10:59:39

Kubernetes容器集群

2022-03-21 08:23:22

Kubernetes容器密钥

2019-07-29 08:03:20

Kubernetes集群服务架构

2020-09-29 10:15:54

开发技能Kubernetes

2022-01-12 11:55:43

2019-02-21 05:38:13

Kubernetes容器云计算

2021-04-14 15:54:20

2021-07-27 11:31:29

2018-05-04 10:48:07

Kubernetes容器K8S

2019-11-07 14:00:36

2020-01-15 10:17:41

Kubernetes容器负载均衡

同话题下的热门内容

一篇文章学会什么是KubernetesKubernetes 可观测性:利用四个开源工具边缘计算已经走过了漫长的道路JuiceFS 在携程海量冷数据场景下的实践风险日益严峻,容器云平台如何做好安全隔离?备份和恢复Kubernetes集群中的Etcd数据IDC:阿里云稳居中国大数据平台公有云市场第一位美国第二大零售商Target公司十年云计算之旅的经验教训

编辑推荐

一文让你看懂IaaS、PaaS和SaaS看完小白也能懂什么是公有云、私有云、混合云陌陌基于K8s和Docker容器管理平台的架构实践科技公司创始人谈MySQL的未来AWS公布AWS媒体服务家族,专为完整视频工作流提供支持
我收藏的内容
点赞
收藏

51CTO技术栈公众号