K8S 集群核心概念 Controller_介绍-分类-Deployment 控制器介绍_创建 Deployment 控制器类型应用 | 学习笔记

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
简介: 快速学习 K8S 集群核心概念 Controller_介绍-分类-Deployment 控制器介绍_创建 Deployment 控制器类型应用

开发者学堂课程【Kubernetes 极速入门:K8S 集群核心概念 Controller_介绍-分类-Deployment 控制器介绍_创建 Deployment 控制器类型应用】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/658/detail/10912


K8S 集群核心概念 Controller_介绍-分类-Deployment 控制器介绍_创建 Deployment 控制器类型应用

 

内容介绍:

一、场景

二、学习目标

三、学习步骤

四、课程内容

 

一、场景

通过前面课程的学习,已经掌握了 Pod 管理操作,过程中发现当删除Pod时是可以直接删除的,如果在生产过程中误操作,Pod 同样也会轻易被删除的,因此,需要在k8s 集群中引入另一种概念 Controller (控制器),用于在 k8s 集群中以 loop 方式监视Pod 状态,如果其发现Pod被删除,将会重新拉起一个 Pod,以让 Pod 一直保持在用户期望状态。

 

二、学习目标

1.了解 Controller 作用

2.了解 Controller 分类

3.了解 Deployment 控制器作用

4.掌握创建 Deployment 控制器类型应用方法

5.掌握删除 Deployment 控制器类型应用方法

 

三、学习步骤

1.Controller 介绍

2.Controller 分类

3.Deployment 控制器介绍

4.创建 Deployment 控制器类型应用

5.删除 Deployment 控制器类型应用

 

四、课程内容

1.Controller 介绍

控制器

●目的:用于对应用运行的资源对象(主要是pod)进行监控

当 Pod 出现问题时,会把Pod重新拉起,以达到用户的期望状态

2.Controller分类

常见 Pod 控制器:

控制器名称

作用

Deployment

声明式更新控制器,用于发布无状态应用

ReplicaSet

副本集控制器,用于对Pod进行副本规模扩大或剪裁

statefulSet

有状态副本集,用于发布有状态应用

DaemonSet

在k8s集群每一个Node上运行一个副本,用于发布监控或日志收集类等应用(如果想要对整个k8s集群所有的节点,例如master节点和work节点进行监控,或者对其进行日志收集,可以使用DaemonSet控制器。)

Job

运行一次性作业任务(例如执行一个同步时间)

CronJob

运行周期性作业任务

3.Deployment 控制器介绍

●具有上线部署、滚动升级、创建副本、回滚到以前某一版本(成功/稳定)等功能。

●Deployment 包含 ReplicaSet,除非需要自定义升级功能或者根本不需要升级Pod,否则还是建议使用 Deployment 而不直接使用 Replica Set 。

4.创建 Deployment 控制器类型应用

方式一:通过 Kubect 命令行创建

命令

[rootemaster1 ~]# kubectl run nginx-app --image=nginx: latest -

-image-pu11-policy=IfNotPresent --replicas=2(通过两个pod运行起来)

输出

dep1oyment.apps/nginx-app created

具体操作:

[ root@master1 yamldir]# kubectl run nginx-app1 --image=nginx:latest --image-pull-

policy=IfNotPresent -- replicas=2

kubectl run --generator=deployment/apps.v1 is DEPRECATED and will be removed in a future version. Use kubectl run --generator=run-pod/vl or kubectl create instead

deployment.apps/nginx-app1 created

如何查看已经创建的应用

说明

nginx-app 是 deployment 控制器类型的应用名称

nginx : latest 是应用运行的 Pod 中的 Container 所使用的镜像

IfNotPresent 是 container 容器镜像下载策略,如果本地有镜像,使用本地,如果本地没有镜像,下载镜像

--replicas=2是指应用运行的 Pod 共计2个副本,这是用户的期望值,

Deployment 控制器中的 Replicaset 控制器会一直监控此应用运行的 Pod 副本状态,如果数量达不到用户期望,就会重新拉起一个新的 Pod,会让 Pod 数量一直维持在用户期望值数量。

命令

查看 Deployment 控制器类型应用

[rootemaster1 ~]#kubect1 get deployment.apps

命令

查看 Replicaset 控制器类型

[root@master1 ~]#kubectl get replicaset

命令

查 Pod 状态

[root@master1 ~]# kubectl get pods

具体操作:

[ root@master1 yamldir]#kubectl get deployment

NAME              READY      UP -TO-DATE       AVAILABLE       AGE

nginx-app1           2/2            2                2           75s

[ root@master1 yamldir]#kubectl get replicaset

NAME                  DESIRED      CURRENT       READY       AGE

nginx- app1-57c7c9c89d      2             2            2         2m12s

[ roptamaster1 yamldir]#kubectl get pods

NAME                    READY      STATUS    RESTARTS         AGE

nginx-app1-57c7c9c89d-qp8h8   1/1       Running       0           2m50s

nginx-app1-57c7c9c89d-tq868   1/1       Running       0          2m50s

访问 Pod

[ root@master1 yamldir]#kubectl get pods -o wide

NAME            READY       STATUS      RESTARTS      AGE       IP

NODE       NOMINATED NODE        READINESS GATES

nginx-app1-57c7c9c89d-qp8h8  1/1  Running       0       3m31s   172 .16.235.130

worker1  <none>         <none>

nginx-app1-57c7c9c89d-tq868   1/ 1  Running      0       3m31s     172.16 .189.66

worker2   <none>    <none>

[ root@master1 yamldir]# curl http://172.16.189.66

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
1天前
|
Kubernetes 监控 调度
【赵渝强老师】K8s的DaemonSet控制器
DaemonSet控制器确保每个节点上运行一个Pod副本,适用于监控、日志收集等场景。通过示例创建DaemonSet并查看Pod信息,展示了其自动扩展和回收的能力。视频讲解和代码示例详细说明了DaemonSet的使用方法和调度机制。
|
1天前
|
Kubernetes 应用服务中间件 nginx
【赵渝强老师】K8s中的Deployment控制器
Kubernetes中的Deployment用于部署无状态应用程序,管理Pod的数量、更新方式和资源限制。通过创建和管理ReplicaSet,Deployment可以实现Pod的自动扩缩容、滚动更新和回滚。本文介绍了Deployment的基本概念,并通过一个具体的示例演示了如何使用Deployment创建、更新和管理Pod。
|
16天前
|
JSON Kubernetes 容灾
ACK One应用分发上线:高效管理多集群应用
ACK One应用分发上线,主要介绍了新能力的使用场景
|
1天前
|
存储 Kubernetes 调度
【赵渝强老师】K8s中Deployment控制器与StatefulSet控制器的区别
K8s中的Deployment控制器用于管理无状态应用程序,关注Pod数量、更新方式等;而StatefulSets控制器则管理有状态应用程序,提供持久存储和唯一标识符,适用于需要稳定网络标识符和持久化存储的场景。两者的主要区别在于是否维护状态和顺序。
|
1天前
|
存储 Kubernetes 调度
【赵渝强老师】K8s的有状态控制器StatefulSet
在Kubernetes中,StatefulSets用于部署有状态应用程序,提供持久存储和唯一标识符。与Deployment不同,StatefulSets确保Pod的标识符在重新调度后保持不变,适用于需要稳定网络标识符和持久存储的场景。本文介绍了StatefulSets的创建、扩容与缩容、更新与回滚等操作,并提供了具体示例和视频讲解。
|
1天前
|
Kubernetes Linux 调度
【赵渝强老师】K8s的周期性任务控制器CronJob
本文介绍了K8s中的CronJob控制器,它类似于Linux的crontab命令,用于管理和调度定时作业。CronJob可以设置在未来某一时间运行作业一次或在指定时间点重复运行作业。文章通过一个示例展示了如何创建和使用CronJob控制器,包括创建配置文件、应用配置、查看Pod信息和日志等步骤。同时,还解释了CronJob的时间表示方式及其限制。
|
1天前
|
Kubernetes 调度 容器
【赵渝强老师】K8s的Job控制器多工作队列的并行方式
Kubernetes Job 是一次性任务控制器,用于控制 Pod 中的容器执行特定任务。本文介绍了 Job 控制器的工作原理、运行方式及多工作队列并行执行的示例。示例中创建了 5 个作业,以 3 个队列并行执行,整个过程需 2 分钟。文中还提供了详细的 YAML 文件配置和执行命令。
|
1天前
|
Kubernetes 调度 容器
【赵渝强老师】K8s中Job控制器单工作队列的串行方式
Kubernetes中的Job控制器用于管理一次性任务,确保任务完成后不再重启。本文介绍了Job的工作原理、运行方式及示例,包括创建Job、查看Job和Pod信息等步骤,并附有视频讲解。
|
1天前
|
Kubernetes 双11 容器
【赵渝强老师】Kubernetes中的控制器
Kubernetes通过控制器管理Pod的生命周期,以应对不同场景需求,如Deployment、DaemonSet、Job等。控制器可自动调整Pod数量和重启故障Pod,确保系统稳定运行。视频讲解和详细内容见下文。
|
17天前
|
Kubernetes 持续交付 开发工具
ACK One GitOps:ApplicationSet UI简化多集群GitOps应用管理
ACK One GitOps新发布了多集群应用控制台,支持管理Argo CD ApplicationSet,提升大规模应用和集群的多集群GitOps应用分发管理体验。
下一篇
无影云桌面