1 Star 1 Fork 12

woxixilu/k8s

forked from JC/k8s 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
statefulset.yaml 25.78 KB
一键复制 编辑 原始数据 按行查看 历史
JC 提交于 2019-05-08 00:27 . 添加了pod部分的注释
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556
apiVersion: apps/v1
# <string>指定api资源版本,格式group/version
kind: ReplicaSet
# <string>指定资源类别
metadata:
# <Object>指定元数据,内嵌字段
name: StatefulSet-demo
# <string>指定资源名称
namespace: default
# <string>指定名称空间,默认为default
labels:
# <map[string]string>指定标签格式为k:v,可以多个,每行一个
app: myapp-pod
spec:
# <Object>指定期望状态
serviceName: myapp
# <string> -required- 关联的无头服务资源名
replicas: 3
# <integer> 保持的副本数量
selector:
# <Object>支持下面标签选择器,二选一
matchLabels:
# <map[string]string> 支持给定多个键值对,格式如下
app: myapp
release: canary
matchExpressions:
# <[]Object>基于给的表达式来定义使用标签选择器,格式如下
- {key: tier, operator: In, values: ["cache"]}
# 支持一下操作符:
# In, NotIn: 字段的值必须非空列表
# Exists, NotExists: 字段的值必须未空列表
podManagementPolicy: OrderedReady
# <string> 此项不填的时候为默认串行方式创建和删除pod
# 如果需要并行则将此项目设置为Parallel
template:
# <Object>定义pod副本模版
metadata:
# <Object>指定元数据,内嵌字段
name: myapp-pod
# <string>模版资源名称
# 由于pod有控制器生成,所以此配置基本不生效
# 新建出来的pod名字格式:控制名称-随机字符
labels:
# <map[string]string>指定标签格式为k:v,可以多个,每行一个
app: myapp
release: canary
environmenet: qa
# 用于接受控上面定义的selector标签选择器管理副本数量
# 必须对应上面定义的标签选择器规则,可以比上面多不可以比上面少
spec:
# <Object>指定期望状态
affinity:
# <Object> 配置选择器亲和性
nodeAffinity:
# <Object> 节点亲和性
preferredDuringSchedulingIgnoredDuringExecution:
# <[]Object> 尽量满足的亲和定义,软亲和性
- preference:
# <Object> 尽量满足倾向性
matchExpressions:
# <[]Object> 基于给的表达式来定义使用标签选择器,格式如下
- {key: tier, operator: In, values: ["cache"]}
matchFields:
# <[]Object> 节点字段选择器
- key: zone
# <string> -required-检查标签的key
operator: in
# <string> -required- 等值操作符选择
values:
# <[]string> 给定值
- foo
- bar
weight: 60
# <integer> -required- 定义倾向性权重,多个preference时进行对比
requiredDuringSchedulingIgnoredDuringExecution:
# <Object> 必须满足的亲和定义,硬亲和性
nodeSelectorTerms:
# <[]Object> -required-节点选择器
- matchExpressions:
# <[]Object>基于给的表达式来定义使用标签选择器,格式如下
# 比较常用
- {key: tier, operator: In, values: ["cache"]}
- matchFields:
# <[]Object> 节点字段选择器
- key: zone
# <string> -required-检查标签的key
operator: in
# <string> -required- 等值操作符选择
values:
# <[]string> 给定值
- foo
- bar
podAffinity:
# <Object> pod亲和性
preferredDuringSchedulingIgnoredDuringExecution:
# <[]Object> 尽量满足的亲和定义,软亲和性
- podAffinityTerm:
# <Object> -required-pod尽量满足
topologyKey: kubernetes.io/hostname
# <string> -required- 位置拓扑键,指定与什么位置亲和
namespaces: xxxx
# <[]string> 指定下面设置的pod是哪一个名称空间中的
# 如果不指定默认为当前创建 pod的名称空间中
labelSelector:
# <Object> 标签选择器,选定跟哪一组pod亲和
matchFields:
# <[]Object> 节点字段选择器
- key: zone
# <string> -required-检查标签的key
operator: in
# <string> -required- 等值操作符选择
values:
# <[]string> 给定值
- foo
- bar
matchLabels:
# <map[string]string> 支持给定多个键值对,格式如下
app: myapp
release: canary
weight: 60
requiredDuringSchedulingIgnoredDuringExecution:
# <[]Object> 必须满足的亲和定义,硬亲和性
- topologyKey: kubernetes.io/hostname
# <string> -required- 位置拓扑键,指定与什么位置亲和
namespaces: xxxx
# <[]string> 指定下面设置的pod是哪一个名称空间中的
# 如果不指定默认为当前创建 pod的名称空间中
labelSelector:
# <Object> 标签选择器,选定跟哪一组pod亲和
matchFields:
# <[]Object> 节点字段选择器
- key: zone
# <string> -required-检查标签的key
operator: in
# <string> -required- 等值操作符选择
values:
# <[]string> 给定值
- foo
- bar
matchLabels:
# <map[string]string> 支持给定多个键值对,格式如下
app: myapp
release: canary
podAntiAffinity:
# <Object> pod反亲和性,不能符合下面指定的条件
preferredDuringSchedulingIgnoredDuringExecution:
# <[]Object> 尽量满足的亲和定义,软亲和性
- podAffinityTerm:
# <Object> -required-pod尽量满足
topologyKey: kubernetes.io/hostname
# <string> -required- 位置拓扑键,指定与什么位置亲和
namespaces: xxxx
# <[]string> 指定下面设置的pod是哪一个名称空间中的
# 如果不指定默认为当前创建 pod的名称空间中
labelSelector:
# <Object> 标签选择器,选定跟哪一组pod亲和
matchFields:
# <[]Object> 节点字段选择器
- key: zone
# <string> -required-检查标签的key
operator: in
# <string> -required- 等值操作符选择
values:
# <[]string> 给定值
- foo
- bar
matchLabels:
# <map[string]string> 支持给定多个键值对,格式如下
app: myapp
release: canary
weight: 60
requiredDuringSchedulingIgnoredDuringExecution:
# <[]Object> 必须满足的亲和定义,硬亲和性
- topologyKey: kubernetes.io/hostname
# <string> -required- 位置拓扑键,指定与什么位置亲和
namespaces: xxxx
# <[]string> 指定下面设置的pod是哪一个名称空间中的
# 如果不指定默认为当前创建 pod的名称空间中
labelSelector:
# <Object> 标签选择器,选定跟哪一组pod亲和
matchFields:
# <[]Object> 节点字段选择器
- key: zone
# <string> -required-检查标签的key
operator: in
# <string> -required- 等值操作符选择
values:
# <[]string> 给定值
- foo
- bar
matchLabels:
# <map[string]string> 支持给定多个键值对,格式如下
app: myapp
release: canary
tolerations:
# <[]Object> 污点容忍度设置,当匹配到污点时按照effect执行容忍操作
# 如果节点上有污点,而pod没设置容忍则不会调度到节点上
- effect: NoShedule
# <string> 定义对Pod排斥效果,设置容忍操作
# NoShedule:仅影响调度过程,对现存的Pod对象不产生影响
# NoExecute:既影响调度过程,也影响现在的Pod对象
# 不容忍的Pod对象将被驱逐
# PreferNoSchedule:NoShedule优先
key: "node-type"
# <string> 键
operator: "Exists"
# <string>比较操作符
value: "xxx"
# <string> 值
tolerationSeconds: 3
# <integer> 等多久后被驱逐,默认为0s,马上被驱逐
serviceAccountName: jcadmin
# <string> 指定pod连接apiserver时使用的帐号,需要在外面预先创建
# 也可以用于连接私有的镜像仓库
hostNetwork: false
# <boolean>是否使用HOST主机网络名称空间,默认不使用
hostIPC: false
# <boolean> 是否共享IPC名称空间
hostPID: false
# <boolean>是否共享host主机的PID名称空间
hostname: xxxx
# <string> 如果pod定义了hostname属性则检查节点hostname是否匹配
restartPolicy: Always
# <string> 定义的容器重启策略
# Always(挂了必须重启)
# OnFailure(只有状态为错误时重启)
# Never(从不重启),默认Always
# 重启逻辑为每重启一次加10秒间隔时间,第一重启立即重启,第二次10s后,第三次20s
nodeSelector:
# <map[string]string>节点选择器,用于根据标签选择pod运行在哪个节点上,标签选择格式如下
# 支持两种标签选择器( matchLabels与matchExpressions)
disktype: ssd
nodeName: t1.wft.com
# <string>直接节点标签选择器,直接决定pods运行在哪个节点上
containers:
# <[]Object> -required-指定容器对象资源,可以设置多个每个-name配置段设置一个
- name: myapp
# <string>指定容器名称
resources:
# <Object> 资源请求与限制指标,两个指标需要同时使用
# cpu限制中,1颗虚拟CPU=1000个millicoresCPU
# 因此,500m的cpu等0.5CPU
# 1000进制内存计量单位:E、P、T、G、M、K、
# 1024进制内存计量单位:Ei、Pi、Ti、Gi、Mi、Ki、
# https://kubernetes.io/docs/concepts/configuration/manage-compute-resources-container/
limits:
# <map[string]string>指定pod资源最低需求
cpu: "200m"
memory: "64Mi"
requests:
# <map[string]string>指定pod资源限制最大限制
cpu: "200m"
memory: "64Mi"
image: ikubernetes/myapp:v1
# <string>指定镜像资源
imagePullPolicy: Always
# <string>镜像获取策略,Always(不论有没有总是去仓库), Never(本地有就用,没有就等待)
# IfNotPresent(如果本地存在就使用,没有就下载),如果标签是latest的默认值为Always
# 否则默认值为IfNotPresent,一旦创建不可以更改。
env:
# <[]Object> 定义容器环境变量的两种写法
# 可以使用kv方式定义,可以定义多个
- name: REDIS_HOST
# <string> -required- kv写法,name对应容器来面变量名称
# 每个变量一个name
# 此字段也可以是容器里面服务配置文件里面的变量名称
# 里面定义叫什么这里就要写什么
value: redis.default.svc.cluster.local
#<string> 变量的值
- name: REDIS_HOST
# <string> -required- 引用其他资源写法,name对应容器来面变量名称
# 每个变量一个name
# 此字段也可以是容器里面服务配置文件里面的变量名称
# 里面定义叫什么这里就要写什么
valueFrom:
# <Object> 引用其他对象数据给变量赋值,此段为赋值部分
configMapKeyRef:
# <Object>引用configmap的键值,configmap需要实现创建好
name: nginx-config
# <string> 需要引用configmap资源的名称
key: nginx_port
# <string> -required- 需要在资源对象里面引用的key
optional: flase
# <boolean> 当找不定义引用的key是否忽略报错
fieldRef:
# <Object>引用当前pod的字段,支持如下
fieldPath: spec.nodeName
# spec.nodeName 节点名称
# status.hostIP 节点ip地址
# status.podIP pod对象的ip地址
# metadata.name pod对象名称
# metadata.namespace pod对象名称空间
# metadata.labels['KEY'] pod对象标签中指定键的值
# metadata.annotations['KEY'] pod对象标签中指定键的值
# metadata.uid pod对象的uid
# spec.serviceAccountName pod对象使用的serviceAccountName资源名称
resourceFieldRef:
# <Object> 引用资源需求与限制的数据
secretKeyRef:
# <Object> 引用secret对象资源的数据
name: mysql-root-password
# <string> 引用的configmap资源名称
key: password
# <string> -required- 引用的key
envFrom:
# <[]Object> 同时将多个configmap里面的所有键值导入
- prefix: HTCFG_
# <string> 避免多个configmap引用的键冲突,在每个键前使用前缀
configMapRef:
# <Object>引用configmap的键值,configmap需要实现创建好
name: nginx-config
# <string> 需要引用configmap资源的名称
optional: flase
# <boolean> 当找不定义引用的key是否忽略报错
lifecycle:
# <Object>生命周期钩子
postStart:
# <Object>容器启动后需要执行的工作,如果执行失败会按照重启策略重启容器
exec:
# <Object>执行探针,执行的自定义命令必须是容器存在的
command: ["/bin/sh","-c","mkdir -p /data/web/html; echo 'home page' >> /data/web/html/index.html"]
# <[]string> 执行命令返回成功则表示容器执行成功,否则返回执行失败
httpGet:
# <Object>http探测,返回200,300,301表示OK,其他表示不OK
host: 192.168.0.100
# <string>指定地址,默认为pod的ip地址
path: /index.html
# <string>指定uri
port: 80
# <string> -required-指定端口,或者service名称
# 如果使用名称则需要在容器暴露时设置好才能被调用
scheme: HTTP
# <string>建立连接使用的协议,只可以是HTTP与HTTPS,默认为HTTP
httpHeaders:
# <[]Object>自定义的请求报文首部格式后如下
name: test
# <string> -required-
value: test
# <string> -required-
tcpSocket:
# <Object>tcp探针
host: 192.168.0.100
# <string> 哪个主机,默认为pod的ip地址
port: 80
# <string> -required-哪个端口
preStop:
# <Object>容器终止前需要执行完的工作,执行完才会终止容器
exec:
# <Object>执行探针,执行的自定义命令必须是容器存在的
command: ["/bin/sh","-c","mkdir -p /data/web/html; echo 'home page' >> /data/web/html/index.html"]
# <[]string> 执行命令返回成功则表示容器执行成功,否则返回执行失败
httpGet:
# <Object>http探测,返回200,300,301表示OK,其他表示不OK
host: 192.168.0.100
# <string>指定地址,默认为pod的ip地址
path: /index.html
# <string>指定uri
port: 80
# <string> -required-指定端口,或者service名称
# 如果使用名称则需要在容器暴露时设置好才能被调用
scheme: HTTP
# <string>建立连接使用的协议,只可以是HTTP与HTTPS,默认为HTTP
httpHeaders:
# <[]Object>自定义的请求报文首部格式后如下
name: test
# <string> -required-
value: test
# <string> -required-
tcpSocket:
# <Object>tcp探针
host: 192.168.0.100
# <string> 哪个主机,默认为pod的ip地址
port: 80
# <string> -required-哪个端口
readinessProbe:
# <Object>指定exec|httpGet|tcpSocket其中一种探针用于探测容器中的服务是否能提供服务(就绪性探测)
# 用于判断容器中的服务就绪后的容器才加入service,如果没有设置默认10s加入service
exec:
# <Object>执行探针,执行的自定义命令必须是容器存在的
command: ["test","-e","/tmp/healthy"]
# <[]string> 执行命令返回"0"成功则表示容器执行成功,其他返回均表示失败
httpGet:
# <Object>http探测,返回200,300,301表示OK,其他表示不OK
host: 192.168.0.100
# <string>指定地址,默认为pod的ip地址
path: /index.html
# <string>指定uri
port: 80
# <string> -required-指定端口,或者service名称
# 如果使用名称则需要在容器暴露时设置好才能被调用
scheme: HTTP
# <string>建立连接使用的协议,只可以是HTTP与HTTPS,默认为HTTP
httpHeaders:
# <[]Object>自定义的请求报文首部格式后如下
name: test
# <string> -required-
value: test
# <string> -required-
tcpSocket:
# <Object>tcp探针
host: 192.168.0.100
# <string> 哪个主机,默认为pod的ip地址
port: 80
# <string> -required-哪个端口
failureThreshold: 3
# <integer>探测失败容忍次数,默认为3,最小值为1
periodSeconds: 10
# <integer>每次探测间隔时间,默认10s
timeoutSeconds:
# <integer>每次探测超时时间,默认1s
initialDelaySeconds: 5
# <integer>容器启动后多久开始探测,默认0s
successThreshold: 1
# <integer>当处于失败状态时,检测成功几次才算成功,默认为1
livenessProbe:
# <Object>,指定exec|httpGet|tcpSocket其中一种探测容器是否存活,(存活性探测)
# 用于检查容器,是否健康
exec:
# <Object>执行探针,执行的自定义命令必须是容器存在的
command: ["test","-e","/tmp/healthy"]
# <[]string> 执行命令返回"0"成功则表示容器执行成功,其他返回均表示失败
httpGet:
# <Object>http探测,返回200,300,301表示OK,其他表示不OK
host: 192.168.0.100
# <string>指定地址,默认为pod的ip地址
path: /index.html
# <string>指定uri
port: 80
# <string> -required-指定端口,或者service名称
# 如果使用名称则需要在容器暴露时设置好才能被调用
scheme: HTTP
# <string>建立连接使用的协议,只可以是HTTP与HTTPS,默认为HTTP
httpHeaders:
# <[]Object>自定义的请求报文首部格式后如下
name: test
# <string> -required-
value: test
# <string> -required-
tcpSocket:
# <Object>tcp探针
host: 192.168.0.100
# <string> 哪个主机,默认为pod的ip地址
port: 80
# <string> -required-哪个端口
failureThreshold: 3
# <integer>探测失败容忍次数,默认为3,最小值为1
periodSeconds: 10
# <integer>每次探测间隔时间,默认10s
timeoutSeconds:
# <integer>每次探测超时时间,默认1s
initialDelaySeconds: 5
# <integer>容器启动后多久开始探测,默认0s
successThreshold: 1
# <integer>当处于失败状态时,检测成功几次才算成功,默认为1
ports:
# <[]Object>端口名称,端口号列表,协议,地址,主要是信息性的显示暴露
# 即如果容器本身是暴露端口的,此处就算不指定暴露端口也会被暴露出去,此处与docker的-p不一样
# 可以设置多个每个-name配置段设置一个
- name: http
# <string>指定端口名称
containerPort: 80
# <integer> -required-指定容器暴露的端口
hostIP: 0.0.0.0
# <string>指定节点地址,由于pod创建在集群里头是动态的,所以无法确定节点地址.该字段一般指定0.0.0.0
hostPort: 80
# <integer>指定端口,将宿主机的80端口转发至containerPort定义端口
protocol: TCP
# <string>指定协议,默认TCP
command:
- "/bin/sh"
- "-c"
- "sleep 7200"
# <[]string>用来覆盖容器启动命令,类似docker的Entrypoint,且代码不会运行在shell中
# 如果要运行在shell中必须指明命令
# 如果没有提供command且镜像里面提供了Entrypoint,则运行容器的Entrypoint
args: ["-c", "while true; do echo hello; sleep 10;done"]
# <[]string>容器没有定义CMD时,作为参数传递给容器的Entrypoint
# 容器本身定义了CMD时,则覆盖容器里面的CMD所定义的内容接将args指定作为参数传给Entrypoint
# 变量引用格式$(VAR_NAME),如果不想被引用$$(VAR_NAME)
# command与args详细关系如下:
# https://kubernetes.io/docs/tasks/inject-data-application/define-command-argument-container/#running-a-command-in-a-shell
# 如果没有定义command也没有定义args,则默认使用docker镜像中的Entrypoint与Cmd
# 如果只提供command但没有提供args,则只运行command,镜像中的Entrypoint与Cmd被忽略
# 如果只提供args但没定义command,则使用镜像中的Entrypoint做命令,把args当参数传入,忽略镜像中的Cmd
# 如果提供了command与args,就表示完全自定义参数,镜像中的Entrypoint与Cmd被忽略
volumeMounts:
# <[]Object>指定挂载存储资源配置,可以挂载多个,每个name定义一个
- name: myappdata
# <string> -required- 下面定义好要挂载卷资源的名称
mountPath: /data/web/html
# <string> -required- 挂载在容器的对应路径
readOnly: false
# <boolean>是否要只读挂载,默认为false
subPath:
# <string>挂载卷时使用的子路径
# 即在mountPath指定的路径下使用一个子路径作为其挂载点
volumeClaimTemplates:
# <[]Object> 副本pvc模版,动态生成pvc
# 但pv还是需要预先准备好
- metadata:
# <Object> 指定元数据,内嵌字段
name: myappdata
# <string> 模版资源名称
spec:
# <Object>指定期望状态
accessModes: ["ReadWriteMany","ReadWriteOnce"]
# <[]string>访问模型,不同存储卷支持不同模式,具体参照下面网址
# 访问模型,ReadWriteOnce 单路读写(RWO)
# ReadOnlyMany 多路只读(ROX)
# ReadWriteMany 多路读写操作(RWX)
resources:
# <Object> 条件资源要求,绑定的空间至少多少
limits:
# <map[string]string>绑定空间大小条件要求最大不能超过的大小
# https://kubernetes.io/docs/concepts/configuration/manage-compute-resources-container/
storage: 5Gi
#1024单位 E, P, T, G, M, K, m
#1000单位 Ei, Pi, Ti, Gi, Mi, Ki
requests:
# <map[string]string> 绑定空间大小条件要求,最小要满足的容量大小
# https://kubernetes.io/docs/concepts/configuration/manage-compute-resources-container/
storage: 2Gi
#1024单位 E, P, T, G, M, K, m
#1000单位 Ei, Pi, Ti, Gi, Mi, Ki
selector:
# <Object> 标签选择器,匹配pv的标签来选定绑定存储卷,二选一
matchLabels:
# <map[string]string> 支持给定多个键值对,格式如下
app: myapp
release: canary
matchExpressions:
# <[]Object>基于给的表达式来定义使用标签选择器,格式如下
- {key: tier, operator: In, values: ["cache"]}
# 支持一下操作符:
# In, NotIn: 字段的值必须非空列表
# Exists, NotExists: 字段的值必须未空列表
volumeMode: Filesystem
# <string> 后端存储卷模式,根据类型来选择绑定存储卷的,目前测试阶段
volumeName: myapp
# <string> 此选项直接精确绑定到某个pv存储卷上面
updateStrategy:
# <Object> 指定自定义镜像版本更新策略
rollingUpdate:
# <Object> 如果类型为rollingUpdate,则生效配置
partition: 3
# <integer> 分区更新,默认为0
# partition表示更新边界,如果有5个pod分别编号为0到4
# 如果partition为5,意思是大于等于5的编号将会被更新,那0到4都不更新
# 如果partition为4,意思是大于等于4的编号将会被更新,那0只更新了4个
# 即只更新1个,相当于金丝雀更新,当没问题的时候再将partition改为0
# 接着更新所有
type: rollingUpdate
# <string> 两种更新策略二选一,默认RollingUpdate
# OnDelete (重建,建一个删一个)
# RollingUpdate (滚动更新)
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/kencjw/k8s.git
git@gitee.com:kencjw/k8s.git
kencjw
k8s
k8s
master

搜索帮助