kubernetes 核心技术-Controller

  • 什么是controller
  • Pod和Controller关系
  • Deployment控制器应用场景
  • yaml文件字段说明
  • Deployment控制器部署应用
  • 升级回滚
  • 弹性伸缩
  • 部署有状态应用
  • 创建
  • 部署守护进程DaemonSet
  • 创建
  • 查看
  • job(一次性任务)
  • yaml文件
  • 查看
  • 删除任务
  • cronjob(定时任务)
  • 创建



什么是controller

在集群上管理和运行容器的对象,它是实际存在的,不像pod是抽象的。controller有很多种。可以分为无状态和有状态。

  1. 无状态。认为Pod都是一样的,没有顺序要求,不考虑在哪个node运行,随意伸缩扩展。
  2. 有状态。上面无状态的因素都需要考虑。每个pod独立的,并保持pod启动顺序和唯一性。通过唯一的网络标识符和持久存储保证有序,比如mysql主从。

Pod和Controller关系

pod是通过controller实现应用的运维。比如伸缩,滚动升级等。Pod和controller通过label建立关系。

基于kubernetes的毕业设计 kubernetes技术_Deployment

Deployment控制器应用场景

  1. 部署无状态的应用。如nginx,web服务,微服务等。
  2. 管理Pod和ReplicaSet。
  3. 部署,滚动升级等功能。

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控制器部署应用

基于kubernetes的毕业设计 kubernetes技术_Pod_02


基于kubernetes的毕业设计 kubernetes技术_nginx_03


基于kubernetes的毕业设计 kubernetes技术_nginx_04


基于kubernetes的毕业设计 kubernetes技术_Pod_05

升级回滚

基于kubernetes的毕业设计 kubernetes技术_Pod_06


先下载应用,所以看到有三个pods。当pods启动后就会替换掉旧版本的副本。

基于kubernetes的毕业设计 kubernetes技术_Deployment_07


基于kubernetes的毕业设计 kubernetes技术_Deployment_08


基于kubernetes的毕业设计 kubernetes技术_Pod_09


基于kubernetes的毕业设计 kubernetes技术_Pod_10


基于kubernetes的毕业设计 kubernetes技术_Deployment_11

弹性伸缩

基于kubernetes的毕业设计 kubernetes技术_基于kubernetes的毕业设计_12

部署有状态应用

基于kubernetes的毕业设计 kubernetes技术_nginx_13

创建

基于kubernetes的毕业设计 kubernetes技术_Deployment_14


查看pod,有三个pod,每个都是唯一名称。

基于kubernetes的毕业设计 kubernetes技术_基于kubernetes的毕业设计_15


查看创建无头的service。

基于kubernetes的毕业设计 kubernetes技术_基于kubernetes的毕业设计_16

deployment和statefueset区别:有身份的(唯一标识的),根据主机名+按照一定规则生成域名。每个pod有唯一主机名,唯一域名格式为:
主机名称 .service名称.名称空间.svc.cluster.local
如:nginx-statefulset-0.nginx.default.svc.cluster.local

部署守护进程DaemonSet

在每一个node上运行一个pod,新加入的node也同时运行在一个pod里。例如,在每个node节点安装数据采集工具。

基于kubernetes的毕业设计 kubernetes技术_Deployment_17


先删除。

基于kubernetes的毕业设计 kubernetes技术_Deployment_18

创建

基于kubernetes的毕业设计 kubernetes技术_基于kubernetes的毕业设计_19

查看

基于kubernetes的毕业设计 kubernetes技术_基于kubernetes的毕业设计_20

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

基于kubernetes的毕业设计 kubernetes技术_基于kubernetes的毕业设计_21


镜像太大,在节点上单独拉取

基于kubernetes的毕业设计 kubernetes技术_基于kubernetes的毕业设计_22

查看

基于kubernetes的毕业设计 kubernetes技术_Deployment_23


基于kubernetes的毕业设计 kubernetes技术_nginx_24

删除任务

基于kubernetes的毕业设计 kubernetes技术_Pod_25

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

创建

基于kubernetes的毕业设计 kubernetes技术_Pod_26