Pod 调度基础

1.1.复制控制器 (replicationcontroller rc) : 让你的pod的副本数,保存在你的预期值 , 几乎不用了做副本用

提前编辑好文件

1.创建

复制代码
kubectl apply -f replicationcontroller-nginx.yaml

2.查看

复制代码
kubectl get pod

3.删除一个pod并立即查看pod状态

复制代码
kubectl delete pod nginx-9g78r -n default

4.删除 replicationcontroller

复制代码
kubectl delete -f  replicationcontroller-nginx.yaml

标签选择器 :》标签

标签定义的方式:

基于等时的定义

基于键值对定义方式:app: nginx

基于集合的标签定义方式: (key: app,operator In,values:[nginx])

app:nginx

app:apache

2.1复制集控制器

deployment (部署) (无状态集控制器)
滚动更新,他能够管理复制集控制器

2.创建RS

复制代码
kubectl create -f replicaset-example.yaml   //提前编辑好yaml
查看
kubectl get pod
删除
kubectl delete -f replicaset-example.yaml

3.1无状态服务:nginx, apache, [tomcat] 特性:不会在本地存储持久化数据,没有依赖性

1.编写Deployment

复制代码
vim nginx-deployment

2.使用kubectl create创建Deployment

复制代码
kubectl create -f nginx-deployment.yaml

3.查看状态

复制代码
kubectl get deploy

4.使用rollout查看整个Deployment的创建过程状态

复制代码
kubectl rollout status deployment/nginx-deployment

5.查看这个Deployment 对应的RS

复制代码
kubectl get rs -l app=nginx

6.查看Deployment创建的pod

复制代码
kubectl get pods --show-labels

3.2更新Deployment

7.更新pod的image

复制代码
kubectl set image deployment nginx-deployment nginx=nginx:1.9.1 --record

kubectl set image deployment nginx-deployment nginx=nginx:1.12.0 --record

(3)查看某次更新的详情

复制代码
kubectl rollout history deployment/nginx-deployment --revision=2

4)回滚到指定版本

复制代码
kubectl rollout undo deployment/nginx-deployment --to-revision=2

查看:

复制代码
kubectl rollout history deployment/nginx-deployment

(5)回滚到上次版本

复制代码
kubectl rollout undo deployment/nginx-deployment

4:扩容 deployment

(1)调整 pod 的副本数

复制代码
kubectl scale deployment.v1.apps/nginx-deployment --replicas=3

查看

复制代码
kubectl get pods

有状态集控制器:,mysql,redis,kafka 有依赖

有两种删除方式
非级联删除:kubectl delete statefulset redis-sts --cascade=false
级联删除: kubectl delete statefulset redis-sts

(2)创建 statefulset

复制代码
kubectl create -f redis-statefulset.yaml

(3)查看statefilset 状态

复制代码
kubectl get sts

(4)查看群集状态

复制代码
kubectl get service
kubectl get poapp=redis-sts

2:statefulset扩容

(1)扩容,将副本数修改为 3

复制代码
kubectl scale sts redis-sts --replicas=3

守护进程集控制器 (缩写ds)

特点:副本数和node节点数相同

3:创建 Daemonset

复制代码
kubectl create namespace dev
kubectl create -f daemonset-nginx.yaml

4:查看 Daemonset

复制代码
kubectl get ds -n dev -o wide

5.删除DaemonSet

复制代码
kubectl delete ds pod-controller -n dev

五:CronJob

Cronjob(计划任务,缩写为 cj)用于以时间为基准的周期性地执行任务,这些自动化任务和运行在 Linux系统上的 CronJob 一样

1:创建 cronJob

(2)创建cronjob

复制代码
kubectl create -f cronjob-example.yaml

(3)查看

复制代码
kubectl get cj

等待一会后可以查看生成的 pod

相关推荐
夜月yeyue33 分钟前
Linux内高端内存
linux·运维·单片机·嵌入式硬件·ci/cd·硬件架构
云宏信息38 分钟前
运维效率提升实战:如何用轻量化云管平台统一纳管与自动化日常资源操作
运维·服务器·网络·架构·云计算
XINERTEL38 分钟前
自动化测试的「千里眼」:当RTSM远程控制遇上自动化,测试效率直接拉满
运维·功能测试·自动化·以太网测试
猫豆~1 小时前
nginx实战-PHP——day2
linux·centos·云计算
杨云龙UP1 小时前
MySQL 自动备份与覆盖恢复实战:一套脚本搞定全库/按库备份恢复
linux·运维·数据库·sql·mysql
三小尛1 小时前
Linux的常见指令
linux
starvapour2 小时前
Ubuntu下sudo的免密操作
linux·ubuntu
sjg200104142 小时前
Deepin 20.9 误装gcc-8-base_8.4.0-1ubuntu1~16.04.1_amd64 后卸载
linux·运维·服务器
一帘忧梦2 小时前
linux 系统rcs脚本启动
linux·运维·lua
jerryinwuhan2 小时前
1210_1 Linux
linux·运维·服务器