3.k8s资源控制器rs Deployment Job
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的更多相关文章
- Kubernetes K8S之资源控制器RC、RS、Deployment详解
Kubernetes的资源控制器ReplicationController(RC).ReplicaSet(RS).Deployment(Deploy)详解与示例 主机配置规划 服务器名称(hostna ...
- Kubernetes K8S之资源控制器StatefulSets详解
Kubernetes的资源控制器StatefulSet详解与示例 主机配置规划 服务器名称(hostname) 系统版本 配置 内网IP 外网IP(模拟) k8s-master CentOS7.7 2 ...
- Kubernetes K8S之资源控制器Daemonset详解
Kubernetes的资源控制器Daemonset详解与示例 主机配置规划 服务器名称(hostname) 系统版本 配置 内网IP 外网IP(模拟) k8s-master CentOS7.7 2C/ ...
- Kubernetes K8S之资源控制器Job和CronJob详解
Kubernetes的资源控制器Job和CronJob详解与示例 主机配置规划 服务器名称(hostname) 系统版本 配置 内网IP 外网IP(模拟) k8s-master CentOS7.7 2 ...
- k8s学习-资源控制器
4.3.资源控制器 4.3.1.概念 Kubernetes中内建了很多种controller(控制器),这些相当于一个状态机,用来控制Pod的具体状态和行为. 4.3.2.分类 Replication ...
- Kubernetes的资源控制器和Service(四)
一.定义和分类 1,定义 k8s 中内建了很多控制器(controller ),这些相当于一个状态机,用来控制 Pod 的具体状态和行为. 2,类型 ReplicationController.Rep ...
- Kubernetes-5.Pod资源控制器(1)
docker version:20.10.2 kubernetes version:1.20.1 本文概述Kubernetes Pod资源控制器的ReplicaSet.Deployment.Daemo ...
- K8S ingress控制器
文章转载自: K8S ingress控制器 (一)https://blog.51cto.com/u_13760351/2728917 K8S ingress控制器 (二)https://blog.51 ...
- Prometheus 监控K8S 资源状态对象
Prometheus 监控K8S 资源状态对象 官方文档:https://github.com/kubernetes/kube-state-metrics kube-state-metrics是一个简 ...
随机推荐
- centos7安装部署jumpserver
一.系统环境准备1.查看系统版本 # cat /etc/redhat-release // 查看系统版本 CentOS Linux release (Core) # uname -a // 查看系统信 ...
- static静态和非静态详解
static 作为Java中的一个关键字,用于修饰方法.成员变量(Field),统称为成员. 有static修饰的成员 属于类 1.方法称为静态方法(类方法),Field称为类的属性. 2.静态成 ...
- GPT-2,吓坏创造者的「深度造假写手」
简评: 今年二月份刷屏的 GPT-2 着实厉害,那个生成续写故事的例子更是效果好到吓人一跳,它到底有多厉害,本文略微讲讲.更详细的信息可参考文末 OpenAI 的博客链接. 你能从下面这两段文字里品味 ...
- linux打印彩色输出
在终端生成彩色输出,我们可以使用转义序列来实现. 每种颜色都有对应的颜色码.比如:重置=0,黑色=30,红色=31,绿色=32,黄色=33,蓝色=34,洋红=35,青色=36,白色=37 要打印彩色文 ...
- QByteArray与QString的互相转换
QByteArray baData; QString str = QString(baData); // 反过来转换: QByteArray by1 = str.toLatin1(); QByteAr ...
- Spring的DI和AOP
Spring 为了降低Java开发的复杂性,Spring采取了以下4种关键策略:* 基于POJO的轻量级和最小入侵性编程:* 通过依赖注入和面向接口实现松耦合:* 基于切面和惯例进行声明式编程:* 通 ...
- Vue使用 weui picker 弹出框不消失
前言 最近使用 weui 里面的 datepicker 组件的时候遇到了一个问题: 弹出来 选择年月日的框之后,直接点击导航上的“返回” 按钮,picker 选框不消失,也就是弹出框不消失 weui. ...
- C语言做的句柄程序
以vs2015为例---创建对话框程序 一直下一步,下一步,到最后 通过一个小型程序诸如 microsoft spy++我们可以获悉,窗口中失效按钮的句柄为0x00040AE8,由此我们可以给句柄发 ...
- 移动端ios和安卓input问题
在钉钉开发微应用的时候. 安卓和苹果输入input框的时候.失去焦点和获取焦点会有明显的上下跳动 因此我用绝对定位把位置固定在一个地方.就不会有跳动
- 40 final、finally、finalize的区别
1.final 用于声明属性.方法.类.分别表示属性不可被改变,方法不可被覆盖,类不可被继承. (1)一个类不能既被声明为abstract的,又被声明为final的. (2)被声明为final的变量必 ...