3-3、Pod控制住-pod yml配置解释

pod yml配置参数解释
apiVersion:v1       #必选,版本号,例如v1
kind:Pod       #必选,Pod
metadata:       #必选,元数据
  name:string       #必选,Pod名称,命名需要规范
  namespace:string    #必选,Pod所属于的命名空间,不写的话默认创建在default空间
  labels:      #自定义标签
    - name:string                 #自定义标签名字
  annotations:       #自定义注释
    - name:string#自定义注释列表
spec:       #必选,取值类型为Object,Pod中容器的详细定义
  containers:      #必选,Pod中容器列表
  - name:string             #必选,容器名称,命名需要规范
    image:string            #必选,容器的镜像名称
    imagePullPolicy:[Always| Never | IfNotPresent]    #获取镜像的策略 Alawys表示下载镜像 IfnotPresent表示优先使用本地镜像,否则下载镜像,Nerver表示仅使用本地镜像
    command: [string]    #容器的启动命令列表,如不指定,使用打包时使用的启动命令
    args: [string]     #容器的启动命令参数列表
    workingDir: string    #容器的工作目录
    volumeMounts:    #挂载到容器内部的存储卷配置
    - name: string                 #引用pod定义的共享存储卷的名称,需用volumes[]部分定义的的卷名
      mountPath: string   #存储卷在容器内mount的绝对路径,应少于512字符
      readOnly: boolean   #是否为只读模式
    ports:       #需要暴露的端口库号列表
    - name: string                 #端口号名称
      containerPort: int  #容器需要监听的端口号
      hostPort: int    #容器所在主机需要监听的端口号,默认与Container相同
      protocol: string    #端口协议,支持TCP和UDP,默认TCP
    env:       #容器运行前需设置的环境变量列表
    - name: string                 #环境变量名称
      value: string    #环境变量的值
    resources:       #资源限制和请求的设置
      limits:      #资源限制的设置
        cpu: string    #Cpu的限制,单位为core数,将用于docker run --cpu-shares参数
        memory: string    #内存限制,单位可以为Mib/Gib,将用于docker run --memory参数
      requests:      #资源请求的设置
        cpu: string    #Cpu请求,容器启动的初始可用数量
        memory: string    #内存清楚,容器启动的初始可用数量
    livenessProbe:     #对Pod内个容器健康检查的设置,当探测无响应几次后将自动重启该容器,检查方法有exec、httpGet和tcpSocket,对一个容器只需设置其中一种方法即可
      exec:      #对Pod容器内检查方式设置为exec方式
        command: [string] #exec方式需要制定的命令或脚本
      httpGet:       #对Pod内个容器健康检查方法设置为HttpGet,需要制定Path、port
        path: string
        port: number
        host: string
        scheme: string
        HttpHeaders:
        - name: string
          value: string
      tcpSocket:     #对Pod内个容器健康检查方式设置为tcpSocket方式
         port: number
       initialDelaySeconds: 0  #容器启动完成后首次探测的时间,单位为秒
       timeoutSeconds: 0  #对容器健康检查探测等待响应的超时时间,单位秒,默认1秒
       periodSeconds: 0   #对容器监控检查的定期探测时间设置,单位秒,默认10秒一次
       successThreshold: 0
       failureThreshold: 0
       securityContext:
         privileged:false
    restartPolicy: [Always | Never | OnFailure]#Pod的重启策略,默认值为Always,Always表示一旦不管以何种方式终止运行,kubelet都将重启,OnFailure表示只有Pod以非0退出码退出才重启,Nerver表示不再重启该Pod
    nodeSelector: obeject #设置NodeSelector表示将该Pod调度到包含这个label的node上,以key:value的格式指定
    imagePullSecrets:    #Pull镜像时使用的secret名称,以key:secretkey格式指定
    - name: string
    hostNetwork:false     #是否使用主机网络模式,默认为false,如果设置为true,表示使用宿主机网络
    volumes:       #在该pod上定义共享存储卷列表
    - name: string                 #共享存储卷名称 (volumes类型有很多种)
      emptyDir: {}     #类型为emtyDir的存储卷,与Pod同生命周期的一个临时目录。为空值
      hostPath: string   #类型为hostPath的存储卷,表示挂载Pod所在宿主机的目录
        path: string     #Pod所在宿主机的目录,将被用于同期中mount的目录
      secret:      #类型为secret的存储卷,挂载集群与定义的secre对象到容器内部
        scretname: string  
        items:     
        - key: string
          path: string
      configMap:     #类型为configMap的存储卷,挂载预定义的configMap对象到容器内部
        name: string
        items:
        - key: string
          path: string


spec
containers                <[]Object>  -required-      # 必选参数
name                    <string>    -required-      # 指定容器名称,不可更新
image                   <string>    -required-      # 指定镜像
imagePullPolicy         <string>                    # 指定镜像拉取方式
# Always: 始终从registory拉取镜像。如果镜像标签为latest,则默认值为Always
# Never: 仅使用本地镜像
# IfNotPresent: 本地不存在镜像时才去registory拉取。默认值
env                     <[]Object>                  # 指定环境变量
name                  <string>    -required-      # 变量名称
value                <string>                    # 变量值
valueFrom            <Object>                    # 从文件中读取,不常用
command                 <[]string>                  # 以数组方式指定容器运行指令,替代docker的ENTRYPOINT指令
args                    <[]string>                  # 以数组方式指定容器运行参数,替代docker的CMD指令
workingDir              <string>                    # 指定工作目录,不指定则使用镜像默认值
ports                   <[]Object>                  # 指定容器暴露的端口
containerPort         <integer>   -required-      # 容器的监听端口
name                  <string>                    # 为端口取名,该名称可以在service种被引用
protocol              <string>                    # 指定协议:UDP, TCP, SCTP,默认TCP
hostIP                <string>                    # 绑定到宿主机的某个IP
hostPort              <integer>                   # 绑定到宿主机的端口
resources               <Object>                    # 资源设置
limits                <map[string]string>         # 消耗的最大资源限制,通常设置cpu和memory
requests              <map[string]string>         # 最低资源要求,在scheduler中被用到,通常设置cpu和memory
volumeMounts            <[]Object>                  # 指定存储卷挂载
name                  <string>    -required-      # 存储卷名称
mountPath             <string>    -required-      # 容器内挂载路径
subPath               <string>                    # 存储卷的子目录
readOnly              <boolean>                   # 是否为只读方式挂载
volumeDevices           <[]Object>                  # 配置块设备的挂载
devicePath            <string>    -required-      # 容器内挂载路径
name                  <string>    -required-      # pvc名称
readinessProbe          <Object>                    # 就绪性探测,确认就绪后提供服务
initialDelaySeconds   <integer>                   # 容器启动后到开始就绪性探测中间的等待秒数
periodSeconds         <integer>                   # 两次探测的间隔多少秒,默认值为10
successThreshold      <integer>                   # 连续多少次检测成功认为容器正常,默认值为1。不支持修改
failureThreshold      <integer>                   # 连续多少次检测失败认为容器异常,默认值为3
timeoutSeconds        <integer>                   # 探测请求超时时间
exec                  <Object>                    # 通过执行特定命令来探测容器健康状态
command             <[]string>                  # 执行命令,返回值为0表示健康,不自持shell模式
tcpSocket             <Object>                    # 检测TCP套接字
host                <string>                    # 指定检测地址,默认pod的IP
port                <string>  -required-        # 指定检测端口
httpGet               <Object>                    # 以HTTP请求方式检测
host                <string>                    # 指定检测地址,默认pod的IP
httpHeaders         <[]Object>                  # 设置请求头,很少会需要填写
path                <string>                    # 设置请求的location
port                <string>  -required-        # 指定检测端口
scheme              <string>                    # 指定协议,默认HTTP
livenessProbe           <Object>                    # 存活性探测,确认pod是否具备对外服务的能力,该对象中字段和readinessProbe一致
lifecycle               <Object>                    # 生命周期
postStart             <Object>                    # pod启动后钩子,执行指令或者检测失败则退出容器或者重启容器
exec                <Object>                    # 执行指令,参考readinessProbe.exec
httpGet             <Object>                    # 执行HTTP,参考readinessProbe.httpGet
tcpSocket           <Object>                    # 检测TCP套接字,参考readinessProbe.tcpSocket
preStop               <Object>                    # pod停止前钩子,停止前执行清理工作,该对象中字段和postStart一致
startupProbe            <Object>                    # 容器启动完毕的配置,该配置与readinessProbe一致,在lifecycle和Probe之前运行,失败则重启
securityContext         <Object>                    # 与容器安全相关的配置,如运行用户、特权模式等
initContainers            <[]Object>                  # 初始化容器,执行完毕会退出,用户数据迁移、文件拷贝等
volumes                   <[]Object>                  # 存储卷配置,https://www.yuque.com/duduniao/k8s/vgms23#Ptdfs
restartPolicy             <string>                    # Pod重启策略,Always, OnFailure,Never,默认Always
nodeName                  <string>                    # 调度到指定的node节点, 强制要求满足
nodeSelector              <map[string]string>         # 指定预选的node节点, 强制要求满足
affinity                  <Object>                    # 调度亲和性配置
nodeAffinity            <Object>                    # node亲和性配置
preferredDuringSchedulingIgnoredDuringExecution   <[]Object>  # 首选配置
preference          <Object>    -required-      # 亲和偏好
matchExpressions  <[]Object>                  # 表达式匹配
key             <string>    -required-      # label的key
values          <[]string>                  # label的value,当operator为Exists和DoesNotExist时为空
operator        <string>    -required-      # key和value的连接符,In,NotIn,Exists,DoesNotExist,Gt,Lt
matchFields       <[]Object>                  # 字段匹配,与matchExpressions一致
weight              <integer>   -required-      # 权重
requiredDuringSchedulingIgnoredDuringExecution  <Object>    # 强制要求的配置
nodeSelectorTerms   <[]Object>  -required-      # nodeselect配置,与preferredDuringSchedulingIgnoredDuringExecution.preference一致
podAffinity             <Object>                    # pod亲和性配置
preferredDuringSchedulingIgnoredDuringExecution   <[]Object>  # 首选配置
podAffinityTerm     <Object>    -required-      # 选择器
labelSelector     <Object>                    # pod标签选择器
matchExpressions<[]Object>                  # 表达式匹配
matchLabels     <map[string]string>         # 标签匹配
namespaces        <[]string>                  # 对方Pod的namespace,为空时表示与当前Pod同一名称空间
topologyKey       <string>    -required-      # 与对方Pod亲和的Node上具备的label名称
weight              <integer>   -required-      # 权重
requiredDuringSchedulingIgnoredDuringExecution    <[]Object>  # 强制配置,与requiredDuringSchedulingIgnoredDuringExecution.podAffinityTerm一致
podAntiAffinity         <Object>                    # Pod反亲和性配置,与podAffinity一致
tolerations               <[]Object>                  # 污点容忍配置
key                     <string>                    # 污点的Key,为空表示所有污点的Key
operator                <string>                    # key和value之间的操作符,Exists,Equal。Exists时value为空,默认值 Equal
value                   <string>                    # 污点的值
effect                  <string>                    # 污点的影响行为,空表示容忍所有的行为
tolerationSeconds       <integer>                   # 当Pod被节点驱逐时,延迟多少秒
hostname                  <string>                    # 指定pod主机名
hostIPC                   <boolean>                   # 使用宿主机的IPC名称空间,默认false
hostNetwork               <boolean>                   # 使用宿主机的网络名称空间,默认false
hostPID                   <boolean>                   # 使用宿主机的PID名称空间,默认false
serviceAccountName        <string>                    # Pod运行时的使用的serviceAccount
imagePullSecrets          <[]Object>                  # 当拉取私密仓库镜像时,需要指定的密码密钥信息
name                    <string>                    # secrets 对象名

 

posted @ 2022-11-14 23:44  Sky-wings  阅读(78)  评论(0编辑  收藏  举报