当前位置: 首页 > article >正文

飞天使-k8s知识点26-kubernetes温故知新1-pod

文章目录

        • 创建一个pod
          • pod的启动命令和参数更改
          • pod 镜像拉取策略
        • pod 的三种探针
        • pod 探针的实现方式
          • prestop 和 prestart

创建一个pod
apiVersion: v1 # 必选,API 的版本号
kind: Pod # 必选,类型 Pod
metadata: # 必选,元数据
 name: nginx # 必选,符合 RFC 1035 规范的 Pod 名称
spec: # 必选,用于定义 Pod 的详细信息
 containers: # 必选,容器列表
 - name: nginx # 必选,符合 RFC 1035 规范的容器名称
   image: nginx:1.15.12 # 必选,容器所用的镜像的地址
   ports: # 可选,容器需要暴露的端口号列表
   - containerPort: 80 # 端口号

在这里插入图片描述
一般使用yaml 文件进行创建比较好, 命令的方式实验用而已

pod的启动命令和参数更改
apiVersion: v1 # 必选,API 的版本号
kind: Pod # 必选,类型 Pod
metadata: # 必选,元数据
  name: nginx # 必选,符合 RFC 1035 规范的 Pod 名称
spec: # 必选,用于定义 Pod 的详细信息
  containers: # 必选,容器列表
  - name: nginx # 必选,符合 RFC 1035 规范的容器名称
    image: nginx:1.15.12 # 必选,容器所用的镜像的地址
    command: # 可选,容器启动执行的命令
    - sleep
    - "10"
    ports: # 可选,容器需要暴露的端口号列表
    - containerPort: 80 # 端口号

# 新增command 部分到yaml 文件中,

在这里插入图片描述

pod 镜像拉取策略
always  总是拉取, 当镜像tag 为 latest 时, 且 imagepullpollicy  没有配置, 默认为 always
never  不管是否存在,都会拉取
ifNotPresent ,镜像不存在时拉取镜像,如果tag 为非latest ,且 imagepolicy 未配置,默认为 ifNotPresent 

镜像拉取策略, 驾到 command 同级别里
 imagePullPolicy: IfNotPresent # 可选,镜像拉取策略
pod 的三种探针
种类 说明
startupProbe Kubernetes1.16 新加的探测方式,用于判断容器内的应用程序是否已经启动。如果
配置了 startupProbe,就会先禁用其他探测,直到它成功为止。如果探测失败,Kubelet
会杀死容器,之后根据重启策略进行处理,如果探测成功,或没有配置 startupProbe,
则状态为成功,之后就不再探测。
livenessProbe 用于探测容器是否在运行,如果探测失败,kubelet 会“杀死”容器并根据重启策略
进行相应的处理。如果未指定该探针,将默认为 Success
readinessProbe 一般用于探测容器内的程序是否健康,即判断容器是否为就绪(Ready)状态。如
果是,则可以处理请求,反之 Endpoints Controller 将从所有的 Service 的 Endpoints
中删除此容器所在 Pod 的 IP 地址。如果未指定,将默认为 Success
pod 探针的实现方式
实现方式 说明
ExecAction 在容器内执行一个指定的命令,如果命令返回值为 0,则认为容器健康
TCPSocketAction 通过 TCP 连接检查容器指定的端口,如果端口开放,则认为容器健康
HTTPGetAction 对指定的 URL 进行 Get 请求,如果状态码在 200~400 之间,则认为容器健康


没有探针的pod
apiVersion: v1 # 必选,API 的版本号,这里使用的是 v1 版本
kind: Pod # 必选,资源对象的类型,这里是 Pod
metadata: # 必选,资源对象的元数据
 name: nginx # 必选,资源对象的名称,这里是 nginx
spec: # 必选,资源对象的详细规格说明
 containers: # 必选,Pod 中运行的容器列表
 - name: nginx # 必选,容器的名称,这里是 nginx
   image: nginx:1.15.12 # 必选,容器所用的镜像,这里是 nginx:1.15.12
   imagePullPolicy: IfNotPresent # 镜像拉取策略,这里是 IfNotPresent,表示如果本地有镜像就使用本地镜像,否则从远程仓库拉取
   command: # 可选,容器启动时执行的命令
   - sh
   - -c
   - sleep 10; nginx -g "daemon off;" # 这里是先暂停10秒,然后运行 nginx 服务器
   ports: # 可选,容器需要暴露的端口列表
   - containerPort: 8088 # 容器暴露的端口号,这里是 80
 restartPolicy: Never # Pod 的重启策略,这里是 Never,表示容器退出时不自动重启

配置健康检查,如果是一个java程序,启动时间很慢,则要用startupProbe 探针来减少故障恢复时间

apiVersion: v1 # 必选,API 的版本号,这里使用的是 v1 版本
kind: Pod # 必选,资源对象的类型,这里是 Pod
metadata: # 必选,资源对象的元数据
 name: nginx # 必选,资源对象的名称,这里是 nginx
spec: # 必选,资源对象的详细规格说明
 containers: # 必选,Pod 中运行的容器列表
 - name: nginx # 必选,容器的名称,这里是 nginx
   image: nginx:1.15.12 # 必选,容器所用的镜像,这里是 nginx:1.15.12
   imagePullPolicy: IfNotPresent # 镜像拉取策略,这里是 IfNotPresent,表示如果本地有镜像就使用本地镜像,否则从远程仓库拉取
   command: # 可选,容器启动时执行的命令
   - sh
   - -c
   - sleep 10; nginx -g "daemon off;" # 这里是先暂停10秒,然后运行 nginx 服务器
   readinessProbe: # 可选,用于检查容器是否已经准备好提供服务
     httpGet: # 使用 HTTP GET 请求进行检查
       path: /index.html # 请求的路径
       port: 80 # 请求的端口号
       scheme: HTTP # 请求的协议,HTTP 或 HTTPS
     initialDelaySeconds: 10 # 容器启动后首次进行检查的延迟时间(秒)
     timeoutSeconds: 2 # 检查超时时间(秒)
     periodSeconds: 5 # 检查的间隔时间(秒)
     successThreshold: 1 # 表示检查成功的最小连续成功次数
     failureThreshold: 2 # 表示检查失败的最小连续失败次数
   livenessProbe: # 可选,用于检查容器是否还在运行
     tcpSocket: # 使用 TCP Socket 进行检查
       port: 80 # 检查的端口号
     initialDelaySeconds: 10 # 容器启动后首次进行检查的延迟时间(秒)
     timeoutSeconds: 2 # 检查超时时间(秒)
     periodSeconds: 5 # 检查的间隔时间(秒)
     successThreshold: 1 # 表示检查成功的最小连续成功次数
     failureThreshold: 2 # 表示检查失败的最小连续失败次数
   ports: # 可选,容器需要暴露的端口列表
   - containerPort: 80 # 容器暴露的端口号,这里是 80
 restartPolicy: Never # Pod 的重启策略,这里是 Never,表示容器退出时不自动重启
prestop 和 prestart
apiVersion: v1 # 必选,API 的版本号,这里使用的是 v1 版本
kind: Pod # 必选,资源对象的类型,这里是 Pod
metadata: # 必选,资源对象的元数据
 name: nginx # 必选,资源对象的名称,这里是 nginx
spec: # 必选,资源对象的详细规格说明
 containers: # 必选,Pod 中运行的容器列表
 - name: nginx # 必选,容器的名称,这里是 nginx
   image: nginx:1.15.12 # 必选,容器所用的镜像,这里是 nginx:1.15.12
   imagePullPolicy: IfNotPresent # 镜像拉取策略,这里是 IfNotPresent,表示如果本地有镜像就使用本地镜像,否则从远程仓库拉取
   lifecycle: # 定义容器的生命周期钩子
     postStart: # 容器创建后要执行的操作
       exec: # 使用 exec 执行 shell 命令
         command: # 定义要执行的命令
         - sh
         - -c
         - 'mkdir /data/' # 这里的命令是创建一个名为 /data/ 的目录
     preStop: # 容器停止前要执行的操作
       exec: # 使用 exec 执行 shell 命令
         command: # 定义要执行的命令
         - sh
         - -c
         - sleep 10 # 这里的命令是暂停10秒
   ports: # 可选,容器需要暴露的端口列表
   - containerPort: 80 # 容器暴露的端口号,这里是 80
 restartPolicy: Never # Pod 的重启策略,这里是 Never,表示容器退出时不自动重启

在这里插入图片描述

参考资料: 宽哥


http://www.kler.cn/a/274752.html

相关文章:

  • Vue之版本演进
  • 如何重新设置VSCode的密钥环密码?
  • 基于Spring Boot的智慧农业专家远程指导系统
  • React图标库: 使用React Icons实现定制化图标效果
  • WIN10拖入文件到桌面,文件自动移动到左上角,导致桌面文件错乱
  • AlipayHK支付宝HK接入-商户收款(PHP)
  • 在idea中配置tomcat服务器,部署一个项目(下载教程加链接)
  • 【爬虫】实战-爬取Boss直聘信息数据
  • docker小白第十四天之Portainer与CIG
  • Go语言之函数、方法、接口
  • 数据在内存中的存储(C语言)(难点,需多刷几遍)
  • Nginx发布之后可以使用IP访问,不能使用localhost访问, Nginx发布之后可以使用localhost访问,不能使用IP访问,
  • Selenium WebDriver使用EC来定义显式等待的条件
  • Python内置对象
  • react中useContext的用法
  • 万用表革新升级,WT588F02BP-14S语音芯片助力智能测量新体验v
  • 服务器端(Debian 12)配置jupyter与R 语言的融合
  • Java项目基于SpringBoot和Vue的时装购物系统的设计与实现
  • C#基础语法学习笔记(传智播客学习)
  • [Qt学习笔记]Halcon窗口界面上显示文字的字体尺寸、样式修改
  • GO-Gin-Example 第六部分 将Golang应用部署到Docker
  • 【MySQL】知识点 + 1
  • 什么是Spring Boot
  • 字符串函数---(1)
  • 离散制造企业MES与流程企业MES的区别
  • LiveGBS流媒体平台GB/T28181功能-HTTPS 服务支持配置开启什么时候需要开启HTTPS测试SSL证书配置HTTPS测试证书