K8S Pod 基本使用

K8S Pod 基本使用

Pod基本概念

Pods是在Kubernetes集群中创建和管理最小的部署单元,一个Pod内部可以运行一个或多个容器,多个容器之间具共享的存储和网络资源,共享运行上下文。Pod共享运行时上下文是通过linux 命名空间实现,不同的命名空间存储、网络、CPU相互隔离。Pod基于Docker容器进一步进行了抽象,类似于一组具有共享命名空间、共享文件存储的容器组。

使用Pod

  • Pod 模版文件

    # 版本信息
    apiVersion: v1
    # 对象类型
    kind: Pod
    # pod 元数据定义
    metadata:
      name: nginx
    spec:
    # docker 镜像定义
      containers:
      - name: nginx
        image: nginx:1.14.2
        ports:
        - containerPort: 80
    
  • 创建Pod

    # 根据配置文件创建或更新一个Pod对象
    kubectl apply -f https://k8s.io/examples/pods/simple-pod.yaml
    
  • 查看Pod

    kubectl get po
    

    在这里插入图片描述

  • 查看Pod日志

    # kubectl logs pod-name
    kubectl logs balanced-7f6bc49b89-jzrxr
    

    在这里插入图片描述

  • 查看Pod详细信息

    # nginx 为pod的名称
    kubectl describe pods/nginx
    

    在这里插入图片描述

使用规范

通常情况下,用户并不会直接使用Pod进行作业。一般会使用更加高级的对象如Deployment、RS、RC进行作业。即便如此,学习Pod的底层原理和使用规范,对于学习K8S有很大的帮助。Pod 在K8S集群中通常有两种使用方式

  • Pod 运行单个容器 - “每个Pod一个容器”模型是最常见的Kubernetes用例;在这种情况下,您可以将Pod视为单个容器的包装器;Kubernetes管理Pods,而不是直接管理容器。
  • Pod 运行多个容器 - 运行需要一起工作的多个容器的Pod。Pod可以封装由多个紧密耦合且需要共享资源的位于同一位置的容器组成的应用程序。这些位于同一位置的容器形成了一个统一的服务单元,Pod将这些容器、存储资源和短暂的网络标识包装为一个单元。

Pod生命周期

运行阶段

Pod的状态字段是一个PodStatus对象,它有一个阶段字段。Pod的阶段是对Pod在其生命周期中所处位置的简单、高级概括。

ValueDescription
Pending挂起阶段,Pod已被K8S系统接收,但仍有一个或者多个容器未被创建,可以通过kubectl describe 查看pending 状态原因
Running运行阶段,Pod已经被绑定到一个节点上,并且所有的容器都已经被创建,而且至少有一个是运行状态,正在启动或者重启,可以通过kubectl logs 查看Pod日志
Succeeded成功阶段。所有容器执行成功并终止,并且不会再次重启,可以通过kubectl logs 查看Pod 日志
Failed失败阶段。所有容器都已终止,并且至少有一个容器以失败的方式终止,也就是说这个容器要么以非零状态退出,要么被系统终止,可以通过logs 和 describe 查看Pod日志和状态
Unknown未知阶段,通常由于通信问题造成的无法获取Pod状态

容器状态

除了整个Pod的阶段,Kubernetes还跟踪Pod中每个容器的状态。您可以使用容器生命周期挂钩来触发事件,以在容器生命周期的某些点运行。

一旦调度器将Pod分配给Node,kubelet就开始使用容器运行时为该Pod创建容器。有三种可能的容器状态:等待、运行和终止。

要检查Pod容器的状态,可以使用kubectl describe Pod<name of Pod>。输出显示该Pod中每个容器的状态。

  • Waiting

    如果容器未处于“正在运行”或“已终止”状态,则为“正在等待”。处于等待状态的容器仍在运行完成启动所需的操作:例如,从容器映像注册表中提取容器映像,或应用机密数据。当您使用kubectl查询一个容器为Waiting的Pod时,还会看到一个Reason字段来总结容器处于该状态的原因。

  • Running

    正在运行状态表示容器正在执行而没有问题。如果配置了postStart钩子,那么它已经执行并完成了。当您使用kubectl查询容器处于运行状态的Pod时,您还可以看到有关容器何时进入运行状态的信息。

  • Terminated

    处于Terminated状态的容器开始执行,然后运行完成或由于某种原因失败。当您使用kubectl查询容器已终止的Pod时,您会看到原因、退出代码以及该容器执行期间的开始和结束时间。

    如果容器配置了preStop钩子,则该钩子在容器进入Terminated状态之前运行。

容器探针

生产环境中,进程正常启动并不代表能正产的处理业务请求,所以需要有一套合理的健康检查机制。探针是kubelet在容器上定期执行的诊断。目前K8S有三种方式进行探针检测:

  • ExecAction - 在容器内执行一个指定的命令,如果命令返回为0,则认为容器健康
  • TCPSocketAction - 通过TCP连接检查容器指定端口,如果端口开放,则认为容器健康
  • HTTPGetAction - 对特定的URL进行请求,如果状态码在200-400 之间,则认为容器健康

健康检查方法

使用探针检查容器有四种不同的方法。每个探针必须精确定义以下四种机制之一:

  • exec - 在容器内执行指定的命令。如果命令退出时状态代码为0,则认为诊断成功
  • grpc - 使用gRPC执行远程过程调用。目标应实现gRPC运行状况检查。如果响应状态为 SERVING,则认为诊断成功。gRPC探测是alpha功能,只有在启用GRPContainerProbe功能门时才可用
  • httpGet - 对指定端口和路径上的Pod的IP地址执行HTTP GET请求。如果响应的状态代码在200-400之间,则认为诊断成功
  • tcpSocket - 在指定端口上对Pod的IP地址执行TCP检查。如果端口打开,则认为诊断成功。如果远程系统(容器)在连接打开后立即关闭连接,则视为正常

Pod探针检查,容器返回的结果

  • Success - 容器通过检测
  • Failure - 容器检测失败
  • Unknown - 检测失败 状态未知

Pod探针检查种类

  • startupProbe - 用于判断容器内的应用程序是否启动成功。如果配置了startupProbe,就会先禁用其他探针,直至它成功为止。如果检测失败,kubelet会杀死容器,之后根据重启策略进行处理
  • livenessProbe - 用于探测容器是否在运行,如果探测失败,kubelet会杀死容器并根据重启策略进行相应的处理。如果未指定该探针,默认为Success
  • readinessProbe - 用于检测容器内的程序是否健康,即判断容器是否为就绪(Ready)状态. 如果是,则可以处理请求,否则Endpoints Controller 将从所有Service 的Endpoints 中删除此容器所在的Pod的IP地址。如果未指定,将默认为 Success

重启策略

yaml Pod定义文件中 spec下有一个restartPolicy属性,可能值为Always、OnFailure和Never。默认值为 Always

该属性 - restartPolicy适用于Pod中的所有容器,作用是当Pod容器遇到意外状况奔溃时,指定重启的策略。restartPolicy仅指kubelet在同一节点上重新启动容器。在Pod中的容器退出后,kubelet会以指数级延迟(10s、20s、40s…)重新启动它们,延迟上限为5分钟。一旦容器执行了10分钟而没有任何问题,kubelet就会重置该容器的重新启动回退计时器。如下

apiVersion: batch/v1
kind: Job
metadata:
  name: hello
spec:
  template:
    # This is the pod template
    spec:
      containers:
      - name: hello
        image: busybox:1.28
        command: ['sh', '-c', 'echo "Hello, Kubernetes!" && sleep 3600']
      restartPolicy: OnFailure # 指定重启策略
    # The pod template ends here

终止进程

因为Pods表示在集群中的节点上运行的进程,所以允许这些进程在不再需要时优雅地终止是很重要的(而不是突然被KILL信号停止,没有机会清理)。

设计目标是让您能够请求删除并知道进程何时终止,同时也能够确保删除最终完成。当您请求删除Pod时,集群会记录并跟踪Pod被强制终止之前的预期宽限期。随着强有力的停机跟踪到位,kubelet尝试优雅的停机。

# 使用kubectl delete 命令删除pod对象
kubectl delete pods/nginx

# 支持指定时间范围删除pod对象
# 默认30秒内优雅的关闭pod对象 此处设置为10秒
kubectl delete pods/nginx --grace-period=10

在这里插入图片描述

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
Kubernetes (k8s)是一种用于自动化应用程序部署、扩展和管理的开源容器编排平台。在k8s中,Pod是最小的可调度和可管理的单位,也是应用程序的运行实例。 Pod是一组共享资源的容器集合,它们运行在同一个节点上,并共享相同的网络命名空间和存储卷。一个Pod通常包含一个或多个紧密相关的容器,它们共享相同的生命周期和资源。这些容器之间可以通过本地主机上的localhost进行通信。 Pod的设计理念是将一组密切相关的容器放在同一个Pod中,以便它们能够轻松地共享资源,包括存储和网络。Pod可以在Kubernetes上进行水平扩展,即通过增加Pod的数量来增加应用程序的容量和吞吐量。 Pod是临时的和短暂的,它可以在任何时候被创建、销毁或重新创建。这个设计使得应用程序变得弹性和可伸缩,并支持故障恢复。当Pod被销毁时,Kubernetes会自动重新创建一个新的Pod来替代它,以保持应用程序的可用性。 Pod具有唯一的IP地址,并且可以由其他Pod或外部网络访问。它还可以指定一些元数据(如标签和注释),以方便按需选择和管理Pod。通过使用Pod模板,可以定义Pod的规范,包括容器映像、资源要求和环境变量等。 总之,Pod是Kubernetes中的基本概念,它是一组紧密相关的容器的运行实例。Pod提供了容器之间共享资源的环境,并支持弹性扩展和故障恢复。通过使用Pod,我们可以更高效地管理和部署我们的应用程序。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值