k8s中YAML详解

资源编排YAML详解

apiVersion: v1    #指定api版本,此值必须在kubectl apiversion中 
kind: Pod         #指定创建资源的角色/类型 
metadata:         #资源的元数据/属性 
  name: web04-pod #资源的名字,在同一个namespace中必须唯一 
  labels:         #设定资源的标签
    k8s-app: apache 
    version: v1 
    kubernetes.io/cluster-service: "true" 
  annotations:            #自定义注解列表 
    - name: String        #自定义注解名字 
spec:                   #specification of the resource content 指定该资源的内容 
  restartPolicy: Always #表明该容器一直运行,默认k8s的策略,在此容器退出后,会立即创建一个相同的容器 
  nodeSelector:         #节点选择,先给主机打标签kubectl label nodes kube-node1 zone=node1 
    zone: node1 
  containers: 
  - name: web04-pod   #容器的名字 
    image: web:apache #容器使用的镜像地址 
    imagePullPolicy: Never #三个选择Always、Never、IfNotPresent,每次启动时检查和更新(从registery)images的策略,
                           # Always,每次都检查
                           # Never,每次都不检查(不管本地是否有)
                           # IfNotPresent,如果本地有就不检查,如果没有就拉取
    command: ['sh']  #启动容器的运行命令,将覆盖容器中的Entrypoint,对应Dockefile中的ENTRYPOINT 
    args: ["$(str)"] #启动容器的命令参数,对应Dockerfile中CMD参数 
    env: #指定容器中的环境变量 
    - name: str #变量的名字 
      value: "/etc/run.sh" #变量的值 
    resources:  #资源管理
      requests: #容器运行时,最低资源需求,也就是说最少需要多少资源容器才能正常运行 
        cpu: 0.1     #CPU资源(核数),两种方式,浮点数或者是整数+m,0.1=100m,最少值为0.001核(1m)
        memory: 32Mi #内存使用量 
      limits:   #资源限制最大范围 
        cpu: 0.5 
        memory: 64Mi 
    ports: 
    - containerPort: 80  #容器开发对外的端口
      name: httpd        #名称
      protocol: TCP 
    livenessProbe:       #pod内容器健康检查的设置
      httpGet:           #通过httpget检查健康,返回200-399之间,则认为容器正常 
        path: /          #URI地址 
        port: 80 
        #host: 127.0.0.1 #主机地址 
        scheme: HTTP 
      initialDelaySeconds: 180   #表明第一次检测在容器启动后多长时间后开始 
      timeoutSeconds: 5          #检测的超时时间 
      periodSeconds: 15          #检查间隔时间 
      #也可以用这种方法 
      #exec: 执行命令的方法进行监测,如果其退出码不为0,则认为容器正常 
      #  command: 
      #    - cat 
      #    - /tmp/health 
      #也可以用这种方法 
      #tcpSocket: //通过tcpSocket检查健康  
      #  port: number  
    lifecycle:     #生命周期管理 
      postStart:   #容器运行之前运行的任务 
        exec: 
          command: 
            - 'sh' 
            - 'yum upgrade -y' 
      preStop:#容器关闭之前运行的任务 
        exec: 
          command: ['service httpd stop'] 
    volumeMounts:    #数据卷挂载
    - name: volume       #挂载设备的名字,与volumes[*].name 需要对应   
      mountPath: /data   #挂载到容器的某个路径下 
      readOnly: True 
  volumes:     #定义一组挂载设备 
  - name: volume   #定义一个挂载设备的名字 
    #meptyDir: {} 
    hostPath: 
      path: /opt   #挂载设备类型为hostPath,路径为宿主机下的/opt,这里设备类型支持很多种 

YAML语言格式

大小写敏感
使用缩进表示层级关系
不支持 Tab 键制表符缩进,只使用空格缩进
缩进的空格数目不重要,只要相同层级的元素左侧对齐即可,通常开头缩进两个空格
符号字符后缩进一个空格,如冒号,逗号,短横杠(-)等
— 表示 YAML 格式,一个文件的开始,用于分隔文件
# 表示注释
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

米利都

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值