热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

k8s之pod讲解

什么是Pod?Pod是一组紧密关联的容器集合,它由一组、一个或多个容器组成,每个Pod还包含了一个Pause容器,Pause容器是Pod的父容器,主要负责僵尸进程的回收管理,通过P

  什么是Pod?

   Pod 是一组紧密关联的容器集合,它由一组、一个或多个容器组成,每个Pod还包含了一个Pause容器,Pause容器是Pod的父容器,主要负责僵尸进程的回收管理,通过Pause容器可以使同一个Pod里面的 多个容器共享存储、网络、PID、IPC等。
  定义一个Pod
   [root@k8s-master01 ~]# vim nginx1.yaml
   apiVersion: v1   # Api的版本号
   kind: Pod        # 定义类型
   metadata:        # 元数据
     name: nginx    # pod名称,命名规范需符合RFC 1035规范
     labels:        # 自定义标签
       app: nginx
   spec:            # 定义容器的详细信息
     containers:    # 容器列表
     - name: nginx  # 容器名称,需符合RFC 1035规范
       image: nginx # 容器所用镜像
       ports:       # 容器要暴露的端口号列表
       - containerPort: 80  端口号
   [root@k8s-master01 ~]# kubectl create -f nginx1.yaml    #创建pod
  

       kubectl get pod nginx -o yaml

      #以yaml格式显示pod的详细信息

   kubectl get pod --show-labels

      #根据yaml文件里定义的标签筛选出符合条件的pod

       kubectl get rc,service

   #查看rc和service列表

      kubectl describe node k8s-master

     #显示node的详细信息

   kubectl describe pod nginx

   #显示pod的详细信息

   kubectl delete -f nginx1.yaml

   #使用删除yaml文件的方式删除pod

 

   kubectl delete pod --all

     #删除所有pod

 

 

  

 

      #进入某个容器

 

   #查看容器日志

 

   #实时查看容器日志,想当于tail -f命令退出ctrl+c

 

   #打开了一个新的yaml文件,在线修改,修改完退出即更新

 

     #将容器80端口映射本地521端口

 

   #查看命名空间,默认创建的pod都在default下,也可创建新的命名空间。

  

 

 

        #删除命名空间biubiubiu     

      Pod生命周期跟Pod重启策略

     
           #pod整个生命周期中的各种状态

 

 

  pod的重启策

  变量Phase的取值还取决于结构体PodSpec中的RestartPolicy变量,这个RestartPolicy变量是用来设置Pod中容器重启策略的,包括三个可选值,分别是Always、OnFailure和Never。

  Always:当容器失效时,由kubelet自动重启容器。

  OnFailure:当容器终止运行或以不正常情况退出(退出码非0),由kubelet自动重启该容器。

  Never:不对容器设置重启策略。

  Pod探针

  startupProbe:

   k8s1.16版本后新加的探测方式,用于判断容器内应用程序是否已经启动,如果配置了startupProbe就会先禁止其他的探测,直到它成功为止,成功后将不在进行探测。

   LivenessProbe:

   用于探测容器是否运行,如果探测失败,kubelet会根据配置的重启策略进行相应的处理。若没有配置该探针,默认就是success。

   存活性探测。判断pod是否需要重启。

   ReadinessProbe:一般用于探测容器内的程序是否健康,它的返回值如果为success,那么就代表这个容器已经完成启动,并且程序已经是

可以接受流量的状态。

   就绪性探测。判断pod是否能够提供正常服务。

  Pod的探测方式

  ExecAction

  在容器内执行一个命令,如果返回值为0,则认为容器健康。

  TcpSocketAction

  通过TCP连接检查容器内的端口是否是通的,如果是通的就认为容器健康。

  HttpGetAction

  通过应该程序暴露的API地址来检查程序是否是正常的,如果状态码为200-400之间,则认为容器健康。

  Pod退出流程

  用户执行删除操作    kubectl delete pod nginx 

  pod状态会变成Terminating状态(这种状态停留默认时间为30秒)

  在30秒期间,会从Endpoint中删除该pod的IP地址,最后执行yaml文件中Prestop命令。

 

 

 

 

 

 

 

 

 

 

  

 

 

 

 

 

 

 

 

 

 

 

 

 

  

 

 

 

 

 

 

 

 

 

 

 


推荐阅读
author-avatar
郑青青11_875
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有