k8s——pod的资源配置文件详解(manifest)
pod的资源配置文件(manifest)
详细介绍pod的资源配置文件(mannifest)的各个字段的含义
元数据
| 字段 | 是否必须 | 类型 | 含义 | 由用户提供 | 备注 |
|---|---|---|---|---|---|
| name | 必须 | str | pod的名称 | 用户提供 | 在同一个namspace中唯一 |
| labels | 不必须 | map[str]str | 用户自主标识的k/y键值对 | 由用户提供 | 多用于service与pod或者replication controller与pod的匹配 |
| uid | 必须 | str | 系统唯一标识pod实例的uid | 非用户提供 | z只读属性,由系统注入 |
| namespace | 不必须 | str | pod所在的namespace | 由用户提供 | 若为空,则默认为default |
定义容器资源
| 字段 | 是否必须 | 类型 | 含义 | 由用户提供 | 备注 |
|---|---|---|---|---|---|
| containers[] | 必须 | str | list | 要在pod内启动所有的container | 由用户提供 |
| containers[].name | 必须 | str | 容器名 | 由用户提供 | 唯一标识容器,在同一个pod内必须独一无二 |
| containers[].image | 必须 | str | 容器使用的docker镜像名 | 由用户提供 | 无备注 |
| containers[].command[] | 不必须 | str list | 启动docker容器时运行的命令 | 由用户提供 | 无备注 |
| containers[].workingDir | 不必须 | str | 命令在docker容器内执行的初始工作目录 | 由用户提供 | 一旦设置无法更新,默认是Docker default |
| containers[].volumeMounts[] | 不必须 | list | 暴露给容器且能够挂载到docker容器文件系统上的所有volume | 由用户提供 | 无备注 |
| containers[].volumeMounts[].name | 不必须 | str | volume名 | 由用户提供 | 代挂载volume的名字,该字段必须与在volume[]中定义的name匹配 |
| containers[].volumeMounts[].mountPath | 不必须 | str | volume在容器内的挂载点路径 | 由用户提供 | 该路径必须是绝对路径且长度不能超过512个字符 |
| containers[].volumeMounts[].readOnly | 不必须 | boolean | 标识该volume是否是只读的 | 由用户提供 | 默认值是dalse,即可读可写 |
定义容器端口和环境
| 字段 | 是否必须 | 类型 | 含义 | 由用户提供 | 备注 |
|---|---|---|---|---|---|
| containers[].ports[] | 非必须 | list | 容器打开的所有端口 | 由用户提供 | 一旦设置便无法更新 |
| containers[].ports[].name | 非必须 | str | 端口名 | 由用户提供 | 在pdo内必须独一无二 |
| containers[].ports[].containersPort | 必须 | int | 容器监听的端口号 | 由用户提供 | 1-65535 |
| containers[].ports[].hostPort | 非必须 | int | 容器端口在宿主机上的端口映射 | 由用户提供 | 1-65535 |
| containers[].ports[].protocol | 非必须 | str | 端口类型 | 由用户提供 | udp或者tcp,默认是tcp |
| containers[].env[] | 非必须 | list | 在容器运行前设置的环境变量 | 由用户提供 | 是一组键值对 |
| containers[].env[] | 非必须 | list | 在容器运行前设置的环境变量 | 由用户提供 | 无备注 |
| containers.[].env[].value | 非必须 | str | 环境变量 | 由用户提供 | 无备注 |
重启策略
| 字段 | 是否必须 | 类型 | 含义 | 由用户提供 | 备注 |
|---|---|---|---|---|---|
| RestartPolicy | 非必须 | str | pod内容器重启策略 | 由用户提供 | 包含3种策略:Always,OnFailure和Never |
volume配置
| 字段 | 是否必须 | 类型 | 含义 | 由用户提供 | 备注 |
|---|---|---|---|---|---|
| volumes[] | 非必须 | list | pod内由容器间共享的所有volume | 由用户提供 | 无备注 |
| volumes[].name | 非必须 | str | volume名 | 由用户提供 | 无备注 |
| volumes[].VolumeSource | 非必须 | object | 代挂载volume的种类 | 由用户提供 | 包括HostPath,EmptDir,GcePersistentDist等多种类型 |
| volumes[].source.emptyDir | 非必须 | object | emptyDir类型volume | 由用户提供 | 默认的volume类型,代表挂载的volume是一个风险pod生命周期的您是目录,emotyDir的值是一个空对象,即:empuytDir:{} |
| volume[].source.hostPath | 非必须 | object | hostPath类型volume | 由用户提供 | 代表挂载的volume是个以及存在与宿主机上的目录。需要指定volumes[].source.hostPath.path |
| volumes[].source.hostPath.path | 非必须 | str | 宿主机上一个暴露给容器的现存目录的路径 | 由用户提供 | 无备注 |
| volumes[].source.gcePersistentDisk | 非必须 | object | GCEPersistentDisk类型的volume | 由用户提供 | 无备注 |
| volumes[].source.gitRepo | 非必须 | object | gitRepo类型volume | 由用户提供 | 代表某个特定版本的git仓库的url |
| volumes[].source.secret | 非必须 | object | secret类型的volume | 不确定 | 用户可以自行提供secret,亦可以采用系统生成的默认secret |
pod使用的dns
| 字段 | 是否必须 | 类型 | 含义 | 由用户提供 | 备注 |
|---|---|---|---|---|---|
| DNSPolicy | 非必须 | list | 定义pod使用DNS的策略 | 由用户提供 | 有两种选择:ClusterFirst和Default,前者代表pod首先使用集群dns,否则代表pod使用kubelet设置的dns。默认值是ClusterFirst |
k8s——pod的资源配置文件详解(manifest)的更多相关文章
- Kubernetes K8S之CPU和内存资源限制详解
Kubernetes K8S之CPU和内存资源限制详解 Pod资源限制 备注:CPU单位换算:100m CPU,100 milliCPU 和 0.1 CPU 都相同:精度不能超过 1m.1000m C ...
- WebConfig配置文件详解
今天看到博客园一位朋友整理的一个WebConfig配置文件详解,觉得不错,转载一下: <?xml version="1.0"?> <!--注意: 除了手动编辑此文 ...
- sqlMapConfig.xml配置文件详解
sqlMapConfig.xml配置文件详解: Xml代码 Xml代码 <? xml version="1.0" encoding="UTF-8" ?& ...
- 【转】nginx服务器安装及配置文件详解
原文:http://seanlook.com/2015/05/17/nginx-install-and-config/ nginx服务器安装及配置文件详解 nginx在工作中已经有好几个环境在使用了, ...
- BIND9配置文件详解模板[转载]
在CU上看到了一篇关于BIND9配置文件详解的文章,感觉不错,现转载了分享一下. //named.conf 注释说明 by shellyxz@163.com// 此文件对bind9的默认配置文件的说明 ...
- mybatis代码生成器配置文件详解
mybatis代码生成器配置文件详解 更多详见 http://generator.sturgeon.mopaas.com/index.html http://generator.sturgeon.mo ...
- MySQL配置文件详解
MYSQL 配置文件详解 “全局缓存”.“线程缓存”,全局缓存是所有线程共享,线程缓存是每个线程连接上数据时创建一个线程(如果没有设置线程池),假如有200连接.那就是200个线程,如果参数设定值是1 ...
- 【JAVAEE学习笔记】hibernate01:简介、搭建、配置文件详解、API详解和CRM练习:保存客户
今日学习:hibernate是什么 一.hibernate是什么 框架是什么: 1.框架是用来提高开发效率的 2.封装了好了一些功能.我们需要使用这些功能时,调用即可.不需要再手动实现. 3.所以框架 ...
- spring4配置文件详解
转自: spring4配置文件详解 一.配置数据源 基本的加载properties配置文件 <context:property-placeholder location="classp ...
- [转帖]nginx服务器安装及配置文件详解
nginx服务器安装及配置文件详解 http://seanlook.com/2015/05/17/nginx-install-and-config/ 发表于 2015-05-17 | 更新于: 2 ...
随机推荐
- Java入门02:IDEA安装教程
Java入门02:IDEA安装教程 下载IDEA 首先进入官网进行下载,地址:https://www.jetbrains.com/idea/download/#section=windows 我这里选 ...
- 力扣438(Java)-找到字符串中所有字母异位词(中等)
题目: 给定两个字符串 s 和 p,找到 s 中所有 p 的 异位词 的子串,返回这些子串的起始索引.不考虑答案输出的顺序. 异位词 指由相同字母重排列形成的字符串(包括相同的字符串). 示例 1: ...
- 开箱即用!Linux 内核首个原生支持,让你的容器体验飞起来!| 龙蜥技术
简介: 本文将从 Nydus 架构回顾.RAFS v6 镜像格式和 EROFS over Fscache 按需加载技术三个角度来分别介绍这一技术的演变历程. 文/阿里云内核存储团队,龙蜥社区高性能存储 ...
- [Unreal] 虚拟现实理论与最佳实践
优秀的虚拟现实场景所需要具备的特点: 真实感.沉浸感.舒适性.流畅性. VR的这些特点上有其它媒体所不具备的优势,主要通过硬件来实现. VR 的沉浸感让用户置身于周围世界,也引发了一些独特的症状: 眼 ...
- Roslyn 将构建时间写入到输出文件
我期望在每次构建完成之后,创建一个文件,在这个文件里面写入是什么时间构建的.这个需求实现非常简单,只需要使用 Target 在构建完成,使用 WriteLinesToFile 方法写入时间到输出文件即 ...
- 2019-4-12-VisualStudio-好用插件集合
title author date CreateTime categories VisualStudio 好用插件集合 lindexi 2019-04-12 09:37:47 +0800 2019-0 ...
- 圈子社交系统--在线了解前后端,APP小程序H5,三端源码交付-多重玩法,新奇有趣。
圈子论坛社区系统,含完整的后台PHP系统.功能:小程序授权登陆,H5和APP,手机号登陆,发帖,建圈子.发活动.圈主可置顶推荐帖子,关注.点赞.评论.交流等.可作为圈子贴吧等自媒体. 一款全开源支持免 ...
- gorm 如何对字段进行comment注释?
type User struct { Model Name string `gorm:"type:char(30);comment:'姓名'"` }
- linux定时任务crontab 周期执行任务
目录 1. crontab主要作用 2. 如何添加crontab 定时任务 3. 计划任务,crontab命令选项: 4. cron文件语法: 5. 查看计划任务 1 创建脚本文件test.py,在文 ...
- ansible系列(23)--ansible的when控制语句
目录 1 when控制语句 1.1 根据不同操作系统安装相同的软件 1.2 为不同centos版本安装httpd软件 1.3 为特定的主机添加Nginx仓库 1.4 判断服务是否正常运行 1 when ...