k8s资源控制器

#控制器类型

ReplicaSet    #rs,确保pod副本数,rs已替代rc
Deployment #管理rs,升级、回滚、扩容pod
DaemonSet #在每个节点运行一个Pod
StateFulSet #解决有状态服务,Pod重新调度后PodName和HostName不变
Job/CronJob #批处理任务/定时任务
HPA #按CPU使用率或自定义metrics扩展Pod数量 Horizontal Pod Autoscaling

#rs实例

#rs-demo.yaml
apiVersion: extensions/v1beta1
kind: ReplicaSet
metadata:
name: rs-demo
spec:
replicas: 2 #副本数量
selector:
matchLabels:
app: nginx
template:
metadata:
labels:
app: nginx
spec:
containers:
- name: nginx-rs
image: alivv/nginx:node
ports:
- containerPort: 80
#创建
kubectl create -f rs-demo.yaml #查看rs
kubectl get rs
kubectl describe rs rs-demo #查看pod
kubectl get pod
kubectl get pod --show-labels #删除所有pod
kubectl delete pod --all
#再次查看,发现pod存在,保持在副本数量
kubectl get pod #删除
kubectl delete -f rs-demo.yaml

#Deployment实例

Deployment -> 创建ReplicaSet(rs) -> 创建Pod

#nginx-deployment.yaml
apiVersion: apps/v1beta1
kind: Deployment
metadata:
name: nginx-deploy
labels:
app: nginx-demo
spec:
replicas: 3
template:
metadata:
labels:
app: nginx
spec:
containers:
- name: nginx
image: alivv/nginx:node
ports:
- containerPort: 80
#创建( --record参数记录命令,方便后续查看变化)
kubectl apply -f nginx-deployment.yaml --record #查看
kubectl get deployments
kubectl get rs
kubectl get pod --show-labels #扩容
kubectl scale deployment nginx-deploy --replicas 5 #Deployment自动扩展
#kubectl autoscale deployment nginx-deployment --min=3 --max=9 --cpu-percent=80 #更新镜像
kubectl set image deployment/nginx-deploy nginx=nginx:alpine #回滚到前一个版本
kubectl rollout undo deployment/nginx-deploy
#查看回滚状态(回滚完成返回值为0 echo $?)
kubectl rollout status deployment/nginx-deploy
#查看历史rs
kubectl get rs
#查看回滚历史
kubectl rollout history deployment nginx-deploy #回滚到指定版本
#kubectl rollout undo deployment nginx-deploy --to-revision=2 #生产建议设置Deployment的.spec.revisionHistoryLimit限制保留revision历史记录数量

Deployment更多参数 https://www.kubernetes.org.cn/deployment

#DaemonSet实例

#nginx-ds.yaml
kind: DaemonSet
apiVersion: apps/v1
metadata:
name: deamonset-example
labels:
app: daemonset
spec:
selector:
matchLabels:
name: deamonset-example
template:
metadata:
labels:
name: deamonset-example
spec:
containers:
- name: nginx
image: alivv/nginx:node
#部署
kubectl create -f nginx-ds.yaml #查看启动node
kubectl get pods -o wide #删除
kubectl delete -f nginx-ds.yaml

#Job实例

可选参数

RestartPolicy 仅支持Never或OnFailure

spec.completions 需要成功运行Pod个数,默认1

spec.parallelism 运行Pod个数,默认1

spec.activeDeadlineSeconds 失败Pod重试最大时间

#job-demo.yaml
apiVersion: batch/v1
kind: Job
metadata:
name: job-demo
spec:
template:
metadata:
name: job-demo
spec:
restartPolicy: Never
containers:
- name: job-test
image: busybox
command: ["bin/sh", "-c", "for n in $(seq 1 9);do echo $n;done"]
#创建
kubectl create -f job-demo.yaml #查看
kubectl get job
kubectl get pod
kubectl log $(kubectl get pod |awk '/job-demo/{print $1}') #删除
kubectl delete -f job-demo.yaml

#cronjob实例

cronjob -> 创建job -> 创建Pod

schedule: "* * * * *" 分 时 日 月 周,相当于Linux定时任务

.spec.startingDeadlineSeconds 启动Job期限,默认没限制

.spec.successfulJobsHistoryLimit 保留完成job数,默认3

.spec.failedJobsHistoryLimit 保留失败job数,默认1

.spec.concurrencyPolicy 并发策略,默认Allow,Forbid禁止,Replace关闭旧的运行新Job

#cronjob-demo.yaml
kind: CronJob
apiVersion: batch/v1beta1
metadata:
name: cronjob-demo
spec:
schedule: "*/1 * * * *" #每分钟执行
jobTemplate:
spec:
template:
spec:
restartPolicy: OnFailure
containers:
- name: cronjob-demo
image: busybox
args:
- /bin/sh
- -c
- echo -n $(hostname) 'cronjob demo ';date +%T
#创建
kubectl create -f cronjob-demo.yaml #查看
kubectl get cronjob kubectl get job
kubectl get pod
kubectl get pod |awk '/cronjob-demo/{print "kubectl logs "$1}' |bash #删除
kubectl delete -f cronjob-demo.yaml

Blog地址 https://www.cnblogs.com/elvi/p/11755712.html

本文git地址 https://gitee.com/almi/k8s/tree/master/notes

3.k8s资源控制器rs Deployment Job的更多相关文章

  1. Kubernetes K8S之资源控制器RC、RS、Deployment详解

    Kubernetes的资源控制器ReplicationController(RC).ReplicaSet(RS).Deployment(Deploy)详解与示例 主机配置规划 服务器名称(hostna ...

  2. Kubernetes K8S之资源控制器StatefulSets详解

    Kubernetes的资源控制器StatefulSet详解与示例 主机配置规划 服务器名称(hostname) 系统版本 配置 内网IP 外网IP(模拟) k8s-master CentOS7.7 2 ...

  3. Kubernetes K8S之资源控制器Daemonset详解

    Kubernetes的资源控制器Daemonset详解与示例 主机配置规划 服务器名称(hostname) 系统版本 配置 内网IP 外网IP(模拟) k8s-master CentOS7.7 2C/ ...

  4. Kubernetes K8S之资源控制器Job和CronJob详解

    Kubernetes的资源控制器Job和CronJob详解与示例 主机配置规划 服务器名称(hostname) 系统版本 配置 内网IP 外网IP(模拟) k8s-master CentOS7.7 2 ...

  5. k8s学习-资源控制器

    4.3.资源控制器 4.3.1.概念 Kubernetes中内建了很多种controller(控制器),这些相当于一个状态机,用来控制Pod的具体状态和行为. 4.3.2.分类 Replication ...

  6. Kubernetes的资源控制器和Service(四)

    一.定义和分类 1,定义 k8s 中内建了很多控制器(controller ),这些相当于一个状态机,用来控制 Pod 的具体状态和行为. 2,类型 ReplicationController.Rep ...

  7. Kubernetes-5.Pod资源控制器(1)

    docker version:20.10.2 kubernetes version:1.20.1 本文概述Kubernetes Pod资源控制器的ReplicaSet.Deployment.Daemo ...

  8. K8S ingress控制器

    文章转载自: K8S ingress控制器 (一)https://blog.51cto.com/u_13760351/2728917 K8S ingress控制器 (二)https://blog.51 ...

  9. Prometheus 监控K8S 资源状态对象

    Prometheus 监控K8S 资源状态对象 官方文档:https://github.com/kubernetes/kube-state-metrics kube-state-metrics是一个简 ...

随机推荐

  1. Delphi 赋值语句和程序的顺序结构

  2. pause模块

    pause模块:暂停脚本执行 # ansible-doc -s pause- name: Pause playbook execution pause: minutes: // 暂停的真实分钟数 pr ...

  3. HMC版本支持

      Target Version Upgrade From Upgrade Instructions Updates Date Available End of Service Models supp ...

  4. 校内题目T2691 桶哥的问题——送桶

    这是一道校内题目,但迷路的蒟蒻们同样被欢迎来此学习QWQ 题目描述: 题目背景 @桶哥本校——皎月pks大佬OrzOrz 买完了桶,桶哥要去送桶. 题目描述 桶哥买了nn个桶, 他要将这些桶送去nn个 ...

  5. 磁盘空间命令df/du/free

    1.df 显示文件系统大小 -h 以易读方式显示 -k KB -m MB -a 显示所有 2. du 显示文件大小 -h 只显示目录 -a 所有 -s 只显示总量 3.free 显示内存 -k -m ...

  6. samba服务和client挂载

    服务端 1.安装samba服务 yum -y install samba 2.创建系统用户 因为Samba 服务程序的数据库要求账户必须在当前系统中已经存在,否则日后创建文件时将导致文件的权限属性混乱 ...

  7. PL/SQL(Procedure Language & Structured Query Language)

    目前的PL/SQL包括两部分,一部分是数据库引擎部分:另一部分是可嵌入到许多产品(如C语言,JAVA语言等)工具中的独立引擎.可以将这两部分称为:数据库PL/SQL和工具PL/SQL. PL/SQL中 ...

  8. Mapnik使用postgres中的栅格数据

    XML: <?xml version="1.0" encoding="utf-8"?> <Map background-color=" ...

  9. 020:reverse函数补充

    补充reverse两点: 1.如若在反转url时,需要添加参数,那么可以传递 kwargs 参数到 reverse 函数中,实例代码如下: '}) ) 2.如若想添加查询字符串参数,则必须手动进行ur ...

  10. jsonp跨域实例

    一.什么是跨域 二.如何解决跨域 1.前端常用 JSONP 2.服务器端配置 HTTP 协议的 header 解析 三.JSONP实现的实例 <!DOCTYPE html> <htm ...