什么是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命令。

 

k8s之pod讲解的更多相关文章

  1. K8s的POD连接数据库时报错

    [root@cccc xxxx]# ./showlog.sh dr iff-dr-1128668949-lb90g 2017-09-29 03:21:57,575 INFO [org.wildfly. ...

  2. k8s之pod与Pod控制器

    k8s中最为重要的基础资源,pod,pod controller,service pod controller类型有多种需要向控制器赋值之后使用: kubectl命令使用 kubectk get no ...

  3. 为什么k8s引入pod概念?

    为什么k8s引入pod概念? 1.可管理性 有些容器天生需要紧密关联,以pod为最小单位进行调度 扩展 共享资源 管理生命周期 例如: 一个容器写日志,一个容器读取日志进行相关内容的展示 2.通信和资 ...

  4. k8s家族Pod辅助小能手Init容器认知答疑?

    k8s家族Pod辅助小能手Init容器认知答疑? k8s集群Init 容器是一种特殊容器,职责是在Pod的生命周期中作为应用容器的前置启动容器. 在很多应用场景中,在 Pod 内的应用容器正式启动之前 ...

  5. k8s 中 Pod 的控制器

    k8s 中 Pod 的控制器 前言 Replication Controller ReplicaSet Deployment 更新 Deployment 回滚 deployment StatefulS ...

  6. k8s之pod连接被拒排查

    k8s之pod连接被拒排查 pod链接被拒 查看pod的时候发现pod的状态为crashloopbackoff 然后看看日志发现报错如下 kubectl -n kf10 logs easydata-r ...

  7. 13.深入k8s:Pod 水平自动扩缩HPA及其源码分析

    转载请声明出处哦~,本篇文章发布于luozhiyun的博客:https://www.luozhiyun.com 源码版本是1.19 Pod 水平自动扩缩 Pod 水平自动扩缩工作原理 Pod 水平自动 ...

  8. k8s创建pod流程

    kubernetes 创建Pod 的 工作流: step.1 kubectl 向 k8s api server 发起一个create pod 请求(即我们使用Kubectl敲一个create pod命 ...

  9. K8s创建pod yaml文件详解

    kubernetes创建pod的yaml文件,参数说明 apiVersion: v1 #指定api版本,此值必须在kubectl apiversion中 kind: Pod #指定创建资源的角色/类型 ...

随机推荐

  1. JuiceFS v1.0.0 Beta1 发布,加强数据安全能力

    在 JuiceFS 开源一周年之际,我们迎来了首个里程碑版本 JuiceFS v1.0.0 Beta1,并将开源许可从 AGPL v3 修改为 Apache License 2.0. JuiceFS ...

  2. 【一个小发现】VictoriaMetrics中:vm-storage的备份文件,无法给单机版使用

    首先导入一个按天的备份: vmrestore-prod \ -configFilePath="/etc/cos/config.ini" \ -credsFilePath=" ...

  3. netty基础知识

    参考 http://www.infoq.com/cn/articles/netty-high-performance 1. 传统 RPC 调用性能差的三宗罪 1)网络传输方式问题 2)序列化方式问题 ...

  4. WebGPU图形编程(1):建立开发环境 <学习引自徐博士教程>

    首先感谢徐博士提供的视频教程,我的博客记录也是学习徐博士进行的自我总结,老徐B站学习视频链接网址:WebGPU图形编程 - 免费视频教程(1):建立开发环境_哔哩哔哩_bilibili 创建之前你需要 ...

  5. vue-cli创建的项目打包成app引入字体图标的问题

    将项目在手机端调试时,发现引入的阿里图标显示不出来,需要在引入的iconfont.css文件夹里给url加上https

  6. Spring 官宣发布 Spring Boot 3.0 第一个里程碑 M1,从 Java 8 提升到 Java 17!

    Spring官方于2022年1月20日发布Spring Boot 3.0.0-M1版本,预示开启了Spring Boot 3.0的里程碑,相信这是通往下一代Spring框架的激动人心的旅程. 接下来一 ...

  7. Rsync安装配置

    一.先准备两台CentOS服务器,假定是 1.172.18.2.225(服务端) 需要配置rsyncd.conf文件 2.172.18.2.227(客户端) 不需要配置rsyncd.conf文件 二. ...

  8. kubernetes之部署traefik-ingress分为http和https

    1 理解Ingress 简单的说,ingress就是从kubernetes集群外访问集群的入口,将用户的URL请求转发到不同的service上.Ingress相当于nginx.apache等负载均衡方 ...

  9. Go语言切片一网打尽,别和Java语法傻傻分不清楚

    前言 我总想着搞清楚,什么样的技术文章才算是好的文章呢?因为写一篇今后自己还愿意阅读的文章并不容易,暂时只能以此为目标努力. 最近开始用Go刷一些题,遇到了一些切片相关的细节问题,这里做一些总结.切片 ...

  10. 中文分词,自然语言处理器NLP。 六月份版本已上线。

    一,  没有对比,就没有伤害,我们分词的优势在哪里?走一波测试. 跑一下CaCl2,看看效果. 二   想要分什么词汇,自己自定义即可. 目前每个月都会出一个新的版本,主要是和金融相关的词汇. 这是6 ...