kubernetes 核心技术-Controller
- 什么是controller
- Pod和Controller关系
- Deployment控制器应用场景
- yaml文件字段说明
- Deployment控制器部署应用
- 升级回滚
- 弹性伸缩
- 部署有状态应用
- 创建
- 部署守护进程DaemonSet
- 创建
- 查看
- job(一次性任务)
- yaml文件
- 查看
- 删除任务
- cronjob(定时任务)
- 创建
什么是controller
在集群上管理和运行容器的对象,它是实际存在的,不像pod是抽象的。controller有很多种。可以分为无状态和有状态。
- 无状态。认为Pod都是一样的,没有顺序要求,不考虑在哪个node运行,随意伸缩扩展。
- 有状态。上面无状态的因素都需要考虑。每个pod独立的,并保持pod启动顺序和唯一性。通过唯一的网络标识符和持久存储保证有序,比如mysql主从。
Pod和Controller关系
pod是通过controller实现应用的运维。比如伸缩,滚动升级等。Pod和controller通过label建立关系。
Deployment控制器应用场景
- 部署无状态的应用。如nginx,web服务,微服务等。
- 管理Pod和ReplicaSet。
- 部署,滚动升级等功能。
yaml文件字段说明
kubectl create deployment web --image=nginx #不能做复用,只能做测试
kubectl create deployment web --image=nginx --dry-run -o yaml > web.yaml #生成yaml文件样板
vim web.yaml
apiVersion: apps/v1
kind: Deployment
metadata:
creationTimestamp: null
labels:
app: web
name: web
spec:
replicas: 1
selector:# 与下面的labels完成匹配
matchLabels:
app: web
strategy: {}
template:
metadata:
creationTimestamp: null
labels: # 完成匹配
app: web
spec:
containers:
- image: nginx
name: nginx
resources: {}
status: {}
Deployment控制器部署应用
升级回滚
先下载应用,所以看到有三个pods。当pods启动后就会替换掉旧版本的副本。
弹性伸缩
部署有状态应用
创建
查看pod,有三个pod,每个都是唯一名称。
查看创建无头的service。
deployment和statefueset区别:有身份的(唯一标识的),根据主机名+按照一定规则生成域名。每个pod有唯一主机名,唯一域名格式为:
主机名称 .service名称.名称空间.svc.cluster.local
如:nginx-statefulset-0.nginx.default.svc.cluster.local
部署守护进程DaemonSet
在每一个node上运行一个pod,新加入的node也同时运行在一个pod里。例如,在每个node节点安装数据采集工具。
先删除。
创建
查看
job(一次性任务)
yaml文件
apiVersion: batch/v1
kind: Job
metadata:
name: pi
spec:
template:
spec:
containers:
- name: pi
image: perl
command: ["perl", "-Mbignum=bpi", "-wle", "print bpi(2000)"]
restartPolicy: Never
backoffLimit: 4
镜像太大,在节点上单独拉取
查看
删除任务
cronjob(定时任务)
//cronjob.yaml
apiVersion: batch/v1beta1
kind: CronJob
metadata:
name: hello
spec:
schedule: "*/1 * * * *"
jobTemplate:
spec:
template:
spec:
containers:
- name: hello
image: busybox
args:
- /bin/sh
- -c
- date; echo Hello from the Kubernetes cluster
restartPolicy: OnFailure
创建