Kubernetes(四) – Pod和Deployment

Kubernetes中有各种各样的组件,对于容器来说Kubernetes最小的单元是由Pod进行组成的,但是我们在使用过程中经常会使用到Deployment来部署我们的应用,其中究竟区别在哪里,我们今天就来一同探索

Kubernetes官方文档:https://kubernetes.io/docs/reference/

Kubernetes官方Git地址:https://github.com/kubernetes/kubernetes

PS:本系列中使用 KubernetesV1.8 RancherV1.6.14

1.Pod最小的单元

Pod封装了一个或多个应用程序的容器(比如nginx等),存储资源,唯一的网络IP以及管理容器的一些选项 Pod标示的是一个部署单元,可以理解为Kubernetes中的应用程序的单个实例,它可能由单个容器组成,也可能由少量紧密耦合并共享资源的容器组成。

如果多个容器在同一Pod下他们公用一个IP所以不能出现重复的端口号,比如在一个Pod下运行两个nginx就会有一个容器异常,一个Pod下的多个容器可以使用localhost来访问对方端口

应为Pod是最小的单元如果在Pod中容器出现异常终止了是不会重启,在实际使用场景下基本不会直接使用Pod而是使用Deployment部署自己的应用

例子:

> vim myapp-pod.yaml
apiVersion: v1
kind: Pod
metadata:
  name: myapp-pod
  labels:
    app: myapp
spec:
  containers:
  - name: myapp-container
    image: busybox
    command: ['sh', '-c', 'echo Hello Kubernetes! && sleep 3600']

> kubectl create -f myapp-pod.yaml
> kubectl get pod
NAME        READY     STATUS    RESTARTS   AGE
myapp-pod   1/1       Running   0          8s

可以在web页面中查看到具体的pod(UI上称为容器组) 查看日志可以看到 删除Pod

> kubectl delete -f myapp-pod.yaml
pod "myapp-pod" delete
  • 18
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: DeploymentPodKubernetes 中的两个重要概念。 DeploymentKubernetes 中用于管理 Pod 副本数量的资源对象,它定义了 Pod 副本的数量、Pod 模板以及更新策略等信息。Deployment 可以保证指定数量的 Pod 副本处于运行状态,并且可以在更新时提供滚动升级的策略,确保应用程序不会出现中断。 Pod 则是 Kubernetes 中最小的可部署对象,它是一组容器的集合,它们共享相同的网络命名空间和存储卷,并在同一节点上运行。Pod 可以包含一个或多个容器,这些容器可以共享文件系统、进程和网络命名空间等资源。PodKubernetes 中最基本的部署单元,而 Deployment 则用于管理 Pod 的生命周期和副本数量。 因此,可以将 Deployment 理解为管理 Pod 副本的控制器,而 Pod 则是 Deployment 管理的对象。在 Kubernetes 中,DeploymentPod 经常一起使用,以确保应用程序的高可用性和可靠性。 ### 回答2: DeploymentKubernetes中的一个资源对象,用于描述和管理应用程序在集群中的部署。它定义了应用程序的副本数量、位置和更新策略等信息。Deployment通过控制器模式监控和维护应用程序的状态,根据需要创建、更新或删除副本。当集群中的节点发生故障或应用程序需要进行水平扩展时,Deployment会自动调整副本的数量,确保应用程序的高可用性和稳定性。 PodKubernetes中的最小部署单元,它是一组容器的集合,可以共享网络和存储资源。Pod中的容器通常与应用程序的不同部分相关联,例如前端、后端、数据库等。Pod作为一个整体部署和运行,它具有自己的IP地址和网络空间,并且可以在同一节点或不同节点上运行。 Deployment通过管理Pod的创建、销毁和更新,为应用程序提供了一种方便的部署和管理方式。当创建一个Deployment时,Kubernetes会自动创建一个或多个Pod,并在集群中的节点上进行分发。Pod中的容器可以通过共享网络和存储资源来进行通信和数据交互,提供了良好的应用程序部署和扩展的基础。此外,Deployment还支持滚动更新策略,可以逐步将旧的Pod替换为新的Pod,实现应用程序的无缝更新和回滚。 总之,Deployment是管理应用程序在Kubernetes集群中部署和更新的资源对象,而Pod是最小的部署单元,用于运行和管理应用程序的容器。它们共同提供了一种高效、可靠的应用程序部署和管理方式。 ### 回答3: DeploymentKubernetes 中的一个资源对象,用于管理应用程序的部署和更新过程。它定义了应用程序的期望状态,并通过控制器来确保实际状态与期望状态一致。Deployment 可以方便地创建和管理 Pod,并提供了一种机制来平滑地升级和回滚应用程序。 PodKubernetes 中最小的可部署单元,由一个或多个容器共享网络和存储资源组成。Pod 中的容器紧密耦合,它们共享同一主机和 IP 地址,并且可以使用 localhost 进行同步和通信。Pod 提供了一种抽象层,使应用程序能够以一种相对无状态的方式运行,而不必担心底层基础设施的细节。 DeploymentPod 之间存在一定的关系。Deployment 可以管理多个 Pod 的部署和更新过程。通过定义 Deployment 资源,可以指定应该创建多少个 Pod,并在需要时自动创建或删除 PodDeployment 还可以指定 Pod 使用哪个容器镜像,并确保 Pod 的副本数符合期望的副本数。 总的来说,Deployment 是用来管理 Pod 的,它提供了一种声明式的方式来定义应用程序的运行方式,包括副本数、容器镜像等。而 Pod 则是实际运行应用程序的最小单元,它由一个或多个容器组成,并共享网络和存储资源。DeploymentPod 的结合可以实现应用程序的自动部署、水平扩展和版本控制等功能,使应用程序更加方便和可靠地运行在 Kubernetes 平台上。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

EmmaShare

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值