YAML 基础


它的基本语法规则如下:

  1. 大小写敏感
  2. 使用缩进表示层级关系
  3. 缩进时不允许使用Tab键,只允许使用空格。
  4. 缩进的空格数目不重要,只要相同层级的元素左侧对齐即可
  5. # 表示注释,从这个字符一直到行尾,都会被解析器忽略

在kubernetes 中,只需要两种结构类型:

  1. Lists
  2. Maps

Maps


Map 是字典,就是一个key:value的键值对

apiVersion: v1
kind: Pod
metadata:name: demo-podlabels:app: myapp
...

YAML 文件转换成 JSON 格式就是

{"apiVersion": "v1","kind": "Pod","metadata": {"name": "demo-pod","labels": {"app": "myapp"}}
}

Lists


Lists 就是列表,说白了就是数组

args- Cat- Dog- Fish

对应的 JSON 格式如下

{"args": [ 'Cat', 'Dog', 'Fish' ]
}

list 的子项也可以是 Maps,Maps 的子项也可以是list如下所示

apiVersion: v1
kind: Pod
metadata:name: demo-podlabels:app: myapp
spec:containers:- name: front-endimage: nginxports:- containerPort: 80- name: flaskapp-demoimage: jcdemo/flaskappports:- containerPort: 5000

转成如下 JSON 格式文件

{"apiVersion": "v1","kind": "Pod","metadata": {"name": "demo-pod","labels": {"app": myapp"}},"spec": {"containers": [{"name": "front-end","image": "nginx","ports": [{"containerPort": "80"}]}, {"name": "flaskapp-demo","image": "jcdemo/flaskapp","ports": [{"containerPort": "5000"}]}]}
}

创建 Pod


apiVersion: v1
kind: Pod
metadata:name: demo-podnamespace: defaultlabels:app: myapptype: pod
spec:containers:- name: myappimage: ikubernetes/myapp:v1ports:- name: httpcontainerPort: 80- name: busyboximage: busybox:latestcommand:- "/bin/sh"- "-c"- "mkdir -p /usr/share/nginx/html; echo $(date) >> /usr/share/nginx/html/test.html;sleep 3600"

pod yaml详解


yaml格式的pod完整内容

apiVersion: v1                    #必选,版本号,例如v1,版本号必须可以用 kubectl api-versions 查询到
kind: Pod                      #必选,Pod
metadata:                      #必选,元数据name: string                    #必选,Pod名称namespace: string               #必选,Pod所属的命名空间,默认为"default"labels:                       #自定义标签- name: string                 #自定义标签名字annotations:                           #自定义注释列表- name: string
spec:                            #必选,Pod中容器的详细定义containers:                       #必选,Pod中容器列表- name: string                        #必选,容器名称,需符合RFC 1035规范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,默认TCPenv:                          #容器运行前需设置的环境变量列表- 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、portpath: stringport: numberhost: stringscheme: stringHttpHeaders:- name: stringvalue: stringtcpSocket:            #对Pod内个容器健康检查方式设置为tcpSocket方式port: numberinitialDelaySeconds: 0       #容器启动完成后首次探测的时间,单位为秒timeoutSeconds: 0          #对容器健康检查探测等待响应的超时时间,单位秒,默认1秒periodSeconds: 0           #对容器监控检查的定期探测时间设置,单位秒,默认10秒一次successThreshold: 0failureThreshold: 0securityContext:privileged: falserestartPolicy: [Always | Never | OnFailure] #Pod的重启策略,Always表示一旦不管以何种方式终止运行,kubelet都将重启,OnFailure表示只有Pod以非0退出码退出才重启,Nerver表示不再重启该PodnodeSelector: obeject         #设置NodeSelector表示将该Pod调度到包含这个label的node上,以key:value的格式指定imagePullSecrets:         #Pull镜像时使用的secret名称,以key:secretkey格式指定- name: stringhostNetwork: 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: stringpath: stringconfigMap:                      #类型为configMap的存储卷,挂载预定义的configMap对象到容器内部name: stringitems:- key: stringpath: string

Kubernets k8s中yml格式与pod yml格式相关推荐

  1. 阿里云上的k8s中某些节点的pod报dns错误,dns解析失败,bad address

    php报错为:php_network_getaddresses:getaddrinfo failed 问题可能出现的位置 这类问题对应的都是dns解析错误.这里我的错误是因为我连接阿里云数据库用的域名 ...

  2. K8S中的pod、services、容器的概念和区别

    K8S中的pod.services.容器的概念和区别 k8s的部署架构 kubernetes中有两类资源,分别是master和nodes,master和nodes上跑的服务如下图: 1 kube-ap ...

  3. 快速替换jar包中.class、.html、.yml格式的文件

    快速替换jar包中.class..html..yml格式的文件 文章目录 快速替换jar包中.class..html..yml格式的文件 背景 下载反编译软件JD-GUI 使用 jd-gui 打开we ...

  4. k8s中hostname, hosts文件, DNS和代理问题, service和pod的访问问题

    全栈工程师开发手册 (作者:栾鹏) 架构系列文章 验证一个域名的ip地址可以使用 nslookup xx.xx..xx 在kubernets中不同命名空间的服务相互访问 涉及到的是Pod和Servic ...

  5. yml格式或者叫做YAML格式数据学习

    what?? .yml 格式操作 yaml YML spirng 4.3+ 推荐使用yaml格式 支持map; list等多种数据格式 YAML工具类 https://yq.aliyun.com/ar ...

  6. 【好文收藏】k8s中Pod 无法正常解析域名:部署 DNS 调试工具排查

    k8s 中 Pod 无法正常解析域名:部署 DNS 调试工具排查 问题描述 最近将 Kubernetes 升级到 1.18.1 版本,不过升级完后,查看工作节点的部分 Pod 无法启动,查看消息全是 ...

  7. K8s中Pod健康检查源代码分析

    了解k8s中的Liveness和Readiness Liveness:  表明是否容器正在运行.如果liveness探测为fail,则kubelet会kill掉容器,并且会触发restart设置的策略 ...

  8. k8s中yaml文件pod的语法(转)

    kubernetes yaml格式的Pod配置文件 # yaml格式的pod定义文件完整内容: apiVersion: v1 #必选,版本号,例如v1 kind: Pod #必选,Pod metada ...

  9. 关于K8s中Pod调度[选择器,指定节点,主机亲和性]方式和节点[coedon,drain,taint]标记的Demo

    写在前面 嗯,整理K8s中pod调度相关笔记,这里分享给小伙伴 博文内容涉及: kube-scheduler组件的简述 Pod的调度(选择器.指定节点.主机亲和性)方式 节点的coedon与drain ...

  10. K8S中删除pod,又被重新创建的问题解决

    情况如下: k8s中的default空间中,有个Nginx的pod 执行删除命令: kubectl delete pod nginx-55f8fd7cfc-4wxzp 删除后,又重新创建了一个pod, ...

最新文章

  1. apache压力测试工具ab
  2. 【LeetCode从零单排】No 3 Longest Substring Without Repeating Characters
  3. python queue 模块教程
  4. 计算机科学在生物信息中的应用,生物信息学在基因组学中的应用
  5. centos7 yum安装docker
  6. Oracle 20c 新特性详解:SQL Macro 宏 SCALAR / TABLE 模式带来的敏捷和便利
  7. Python+Selenium自动化测试:Page Object模式
  8. 古文(诗词文)—— 结构模式与复用
  9. mysql08---优化01
  10. 数据结构与算法-浙江大学陈越数据结构第一章学习
  11. Delphi 鼠标移动
  12. 防火墙 firewall 及端口查看
  13. 生活-急救常识(2)
  14. 常见的十二种逻辑谬误
  15. 【ES6学习】对象的解构赋值
  16. c语言中用age表示年龄的词语,求古代形容年龄的词,比如花甲,古稀之类的,要齐全。谢谢!!...
  17. edusrc教育src漏洞平台
  18. 鲍思语:未来的汽车市场是年轻人的市场
  19. 需求的获取:需求调研中的5W+1H定律
  20. Ultimate Email Toolkit:16种出色的电子邮件工具

热门文章

  1. PDCN/Padavan/老毛子路由器固件复位/无线桥接教程
  2. 推荐系统常用推荐系统算法(协同过滤算法等)-人工智能AI
  3. 深度deepin安装腾达U12无线网卡驱动
  4. MySQL批量插入(使用mybatis实现mysql数据库的批量插入操作)
  5. usb抓包工具 安卓_USB抓包工具(Bus Hound)下载 v6.0.1 官方版
  6. 百度网盘破解版,满速下载不限速【转载,亲测有效】
  7. js 获取浏览器高度、浏览器宽度
  8. 直播送礼物html,哈你直播如何送礼物 哈你直播给主播送礼物步骤【详解】
  9. 音视频编码格式和封装格式的关系和区别是什么?
  10. JavaScript 动态生成表格 及删除表格