Kubernetes中YAML格式的Pod定义文件完整内容详解

Kubernetes中YAML格式的Pod定义文件完整内容详解

Kubernetes中YAML格式的Pod定义文件完整内容详解

apiVersion: v1                       # 版本号
kind: Pod                            # 类型
metadata:                            # 元数据
  name: string                       # Pod名称
  namespace: string                  # Pod所属的命名空间
  labels:                            # 自定义标签列表
    - name: string
  annotations:                       # 自定义注解列表
    - name: string
spec:                                # Pod中的容器的详细定义
  containers:                        # Pod中的容器列表
  - name: string                     # 容器的名称
    image: string                    # 容器的镜像名称
    imagePullPolicy: [Always | Never | IfNotPresent]  #镜像拉取策略,默认值为Always。1.Always:表示每次都尝试重新拉取镜像。2.IfNotPresent:表示如果本地有该镜像,则使用本地的镜像,本地不存在时拉取镜像。3.Never:表示仅使用本地镜像。
    command: [string]                # 容器的启动命令列表,如果不指定,则使用镜像打包使用的启动命令
    arg: [string]                    # 容器的启动命令参数列表
    workingDir: string               # 容器的工作目录
    volumeMounts:                    # 挂载到容器内部的存储卷配置
    - name: string                   # 引用Pod定义的共享存储卷的名称,需使用volumes[]部分定义的共享存储卷名称
      mountPath: string              # 存储卷在容器内Mount的绝对路径,应少于512个字符
      readOnly: boolean              # 是否为只读模式,默认为读写模式
    ports:                           # 容器需要暴露的端口号列表
    - name: string                   # 端口的名称
      containerPort: int             # 容器需要监听的端口号
      hostPort: int                  # 容器所在主机需要监听的端口号,默认与containerPort相同,设置hostPort时,同一台宿主机将无法启动该容器的第2份副本
      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请求,单位为core数,容器启动的初始可用数量
        memory: string               # 内存请求,单位以为MiB、GiB等,容器启动的初始可用数量
    livenessProbe:                   # 对Pod内各容器健康检查的设置,当探测无响应几次之后,系统将自动重启该容器。可以设置的方法包括:exec、httpGet和tcpSocket。对一个容器仅需设置一种健康检查方法
      exec:                          # 对Pod内各容器健康检查的设置
        command: [string]            # exec方式需要指定的命令或者脚本
      httpGet:                       # 对Pod内各容器健康检查的设置,httpget方式。需指定path、port
        path: string
        port: string
        host: string
        scheme: string
        httpHeaders:
        - name: string
          value: string
      tcpSocket:                      # 对Pod内各容器健康检查的设置,tcpSocket方式
        port: number
      initialDelaySeconds: 0      # 容器启动完成后首次探测的时间,单位为s
      timeoutSeconds: 0          # 探测等待响应的超时时间,单位为s,默认1s
      periodSeconds: 0          # 定期探测时间设置,单位s,默认10s探测一次
      successThreshold: 0      
      failureThreshold: 0
    securityContext:
      privileged: false
  restartPolicy: [Always] | Never | OnFailure]    # pod的重启策略,可选值为Always、OnFailure,默认值为Always。1.Always:Pod一旦终止运行,则无论容器是如何终止的,kubelet都将重启它。2.OnFailure:只有Pod以非零退出码终止时,kublete才会重启该容器。如果容器正常结束(退出码为0),则kublete将不会重启它。3.Never:Pod终止后,kublete将退出码报告给Master,不会再重启该Pod。
  nodeSelector: object       # 设置Node的Label,以key:value格式指定,Pod将被调度到具有这些Label的Node上
  imagePullSecrets:        # pull镜像时使用的Secret名称,以name:secretkry格式指定
  - name: string
  hostNetwork: false      # 是否使用主机网络模式,默认值为false,设置为true表示容器使用宿主机网络,不再使用docker网桥,该pod将无法在同一台宿主机上启动第2个副本。
  volumes:            # 在该pod上定义的共享存储卷列表 
  - name: string      # 共享存储卷的名称,在一个pod中每个存储卷定义一个名称,容器定义部分的containers[].volumeMounts[].name将引用该共享存储卷的名称。可以定义多个volume,每个volume的name保持唯一。
    emptyDir: {}      # 类型为emptyDir的存储卷,表示与Pod同生命周期的一个临时目录,其值为一个空对象:emptyDir:{}
    hostPath:        # 类型为hostPath的存储卷,表示挂载Pod所在宿主机的目录,通过volume[].hostPath.path指定
      path: string   # Pod所在主机的目录,将被用于容器中mount的目录
    secret:          # 类型为secret的存储卷,表示挂载集群预定义的cecret对象到容器内部
      secretName: string
      items:
      - key: string
        path: string
    configMap:     # 类型为configMap的存储卷,表示挂载集群预定义的configMap对象到容器内部
      name: string
      items:
      - key: string
        path: string
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值