容器技术基础-Kubernetes 流程及场景

本文涉及的产品
云原生网关 MSE Higress,422元/月
应用实时监控服务-用户体验监控,每月100OCU免费额度
可观测可视化 Grafana 版,10个用户账号 1个月
简介: 容器技术基础-Kubernetes 流程及场景

开发者学习笔记【阿里云云原生助理工程师认证(ACA)课程:容器技术基础-Kubernetes 流程及场景】

课程地址:https://edu.aliyun.com/course/3112075/lesson/19014


容器技术基础-Kubernetes 流程及场景

 

内容介绍:

一、Kubernetes 使用流程

二、Kubernetes 使用场景

 

一、Kubernetes 使用流程

这一小节了解Kubernetes 是如何来工作的他的工作内容工作场景、流程是什么样的

image.png

Kubernetes典型的工作流程左边的图清晰的描述了 Kubernetes是如何实现他的工作机制的首先通过开发人员或者运维人员开始第一步发出运维指令我想干什么期望什么事情? 运维指令会通过 Kubernetes API server去响应指引所有的操作命令会通过API server进行接收。
第二步,API响应迷你通过一系列认证授权pod数据存储到ETCD。创建Deployment资源并初始化
走到第三步控制器监测发现,新的Deployment将该资源加入到内部工作对点通过Deployment创建一个pod这就到了第三步,创建一个pod实例。
第四步创建完成之后,pod相关信息会更新存储到ETCD下分布式存储ETCD用来存储所有Kubernetes相关需要保存的信息。
第五步资源调度会根据pod资源调度规则绑定主机。
第六步,稳定的结果会存储到ETCD上。  
第七步Kubernetes每隔20秒可以自定义这个时间,API server通过Node获取自身NO上所要运行的pop清单通过与自己的内部缓存进行比较新增加pod
第八步Kubernetes创建增加新pod.
第九步,Q proxy出来创建相应的网络规则用于pod的服务发现和负载均衡。
第十步控制器就会监测pod运营状况,删除或者重新创建,我们就能够清晰的看到Kubernetes节点和NO节点的工作原理和我们上面讲的是基本一致的。  

首先API server是统一的指令路口,我们所有的运维操作的命令都是通过API接收,ETCD是整个Kubernetes的一个关键存储,他把所有的记录操作信息都会存储在ETCD上。
Controller manager是负责整个集群的状态的一个监控。 Schedule负责整个资源调度的资源调度器。  底层note节点的供应负责接收主节点发送的命令,处理pod相应的清单。
Kube  proxy就是创建服务发现负载均衡的网络规则。具体的运行的节点上就会在Dog的image上运行相应的pod。,这就是典型的一个Kubernetes整体的一个工作流程,能够按照我们上面所讲述的组件和核心概念,来更好的去理解Kubernetes是如何工作的。


二、Kubernetes 使用场景

(1)调度

image.png
Kubernetes最重要的核心功能是资源调度能够实现集群灵活的资源调度并且能够实现集群的自动化的分配是怎么实现的呢?
首先调度器作为q net的核心组件之一它承载着整个集群的资源调度功能他会根据特定的调度算法和策略,将pod调度到最优的一个工作节点上从而可以更合理的与充分的利用集群的计算资源。使资源更好的服务于业务的上层的需求业务的需求会不断的变化,它会根据业务的变化来寻找更好的节点,去承载业务本身的应用。Kubernetes可以把用户提交的容器放到Kubernetes管理的集群的某一台节点上。
Kubernetes调度器是执行这项能力的组件,它会观测正在被调度的这个容器的大小规格比如说他需要的CPU以及他需要的memory,然后在集群中找到一台相对比较空闲的机器来进行一次placement。也就是一次反之的操作。
在这个例子中,他可能会把红颜色的这个容器放到第二个空闲的机器上来完成一次调度的工作对于每一个新创建的pod或者未被调用的pod调度器,会选择最优的pod去执行这个炮然后pod类的每个容器对资源都有不同的需求,而且pod本身有不同的资源要求因此Pod在被调度到no上之前根据这些特定的资源调度要求需要对集群中的no进行一次过滤就是说会对集群的状态做一次相应的检查在一个集群中满足一个pod调度请求的所有的漏洞节点,称之为可调度节点。
如果没有任何一个洞能够满足pod资源的请求这个漏将会一直停留在一个未调度的状态直到调度期找到合适的no调度器先在集群中找到一个pod的所有可调度节点,然后根据一系列函数对这些可调度节点打分,选出其中得分最高的no来运行pod之后,调度器将这个调度决定通知给QAPI server这个过程就叫做绑定
在做调度决定时,需要考虑的因素包括单独和整体的资源,要求硬件、软件策略限制亲和以及反亲和要求数据矩形负载阶的干扰等。

(2)自动修复

Kubernetes 的主要好处一是它具有管理和维护集群中容器的能力,可以提供服务零停机时间的保障,Pod 或容器出现故障时 Kubernetes 还可以让系统实现"自愈"能力
Kubernetes有一个节点健康检查的工人,他会检测这个集群中所有的数组积,当数组积本身出现故障的时候,或者软件出现故障的时候,这个节点检查健康检查就会自动对它进行发现,下图看见紫色的节点通过节点的健康检查发现一个节点无响应,这时候空的会把运行在失败节点的容器进行自动的迁移,它会迁移到另一个正在健康运行的机器上来完成一个容器的自动功能,这是容器的自愈能力。
image.png

(3)弹性伸缩

Kubernetes 最核心的场景弹性伸缩Kubernetes有业务负载检查的能力,会根据业务承担的负载,对业务进行扩容,实现资源弹性伸缩。

他会检测业务上所有承载的负载如果这个业务本身的CPU或者内存利用率过高,或者响应时间过长,它可以对业务进行扩容
image.png在下面这个例子中,红颜色的过渡繁忙,就可以把红颜色负载从一分变为三分,接下来它就可以通过负载均衡把原来打到第一个红颜色上的负载平均分到三个红颜色上的负载上去,以此来提高响应的时间。

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
13天前
|
Kubernetes Cloud Native Docker
云原生时代的容器化实践:Docker和Kubernetes入门
【10月更文挑战第37天】在数字化转型的浪潮中,云原生技术成为企业提升敏捷性和效率的关键。本篇文章将引导读者了解如何利用Docker进行容器化打包及部署,以及Kubernetes集群管理的基础操作,帮助初学者快速入门云原生的世界。通过实际案例分析,我们将深入探讨这些技术在现代IT架构中的应用与影响。
55 2
|
13天前
|
运维 Kubernetes Cloud Native
云原生技术:容器化与微服务架构的完美结合
【10月更文挑战第37天】在数字化转型的浪潮中,云原生技术以其灵活性和高效性成为企业的新宠。本文将深入探讨云原生的核心概念,包括容器化技术和微服务架构,以及它们如何共同推动现代应用的发展。我们将通过实际代码示例,展示如何在Kubernetes集群上部署一个简单的微服务,揭示云原生技术的强大能力和未来潜力。
|
15天前
|
存储 Kubernetes Docker
【赵渝强老师】Kubernetes中Pod的基础容器
Pod 是 Kubernetes 中的基本单位,代表集群上运行的一个进程。它由一个或多个容器组成,包括业务容器、基础容器、初始化容器和临时容器。基础容器负责维护 Pod 的网络空间,对用户透明。文中附有图片和视频讲解,详细介绍了 Pod 的组成结构及其在网络配置中的作用。
【赵渝强老师】Kubernetes中Pod的基础容器
|
2天前
|
Kubernetes Cloud Native API
深入理解Kubernetes——容器编排的王者之道
深入理解Kubernetes——容器编排的王者之道
15 1
|
11天前
|
安全 持续交付 云计算
揭秘云计算中的容器化技术及其优势
揭秘云计算中的容器化技术及其优势
19 1
|
11天前
|
缓存 监控 开发者
掌握Docker容器化技术:提升开发效率的利器
在现代软件开发中,Docker容器化技术成为提升开发效率和应用部署灵活性的重要工具。本文介绍Docker的基本概念,并分享Dockerfile最佳实践、容器网络配置、环境变量和秘密管理、容器监控与日志管理、Docker Compose以及CI/CD集成等技巧,帮助开发者更高效地利用Docker。
|
13天前
|
Kubernetes Cloud Native Docker
云原生技术探索:容器化与微服务的实践之道
【10月更文挑战第36天】在云计算的浪潮中,云原生技术以其高效、灵活和可靠的特性成为企业数字化转型的重要推手。本文将深入探讨云原生的两大核心概念——容器化与微服务架构,并通过实际代码示例,揭示如何通过Docker和Kubernetes实现服务的快速部署和管理。我们将从基础概念入手,逐步引导读者理解并实践云原生技术,最终掌握如何构建和维护一个高效、可扩展的云原生应用。
|
15天前
|
Cloud Native 持续交付 Docker
Docker容器化技术:从入门到实践
Docker容器化技术:从入门到实践
|
15天前
|
运维 Kubernetes Shell
【赵渝强老师】K8s中Pod的临时容器
Pod 是 Kubernetes 中的基本调度单位,由一个或多个容器组成,包括业务容器、基础容器、初始化容器和临时容器。临时容器用于故障排查和性能诊断,不适用于构建应用程序。当 Pod 中的容器异常退出或容器镜像不包含调试工具时,临时容器非常有用。文中通过示例展示了如何使用 `kubectl debug` 命令创建临时容器进行调试。
|
15天前
|
Kubernetes 调度 容器
【赵渝强老师】K8s中Pod中的业务容器
Pod 是 Kubernetes 中的基本调度单元,由一个或多个容器组成。除了业务容器,Pod 还包括基础容器、初始化容器和临时容器。本文通过示例介绍如何创建包含业务容器的 Pod,并提供了一个视频讲解。示例中创建了一个名为 "busybox-container" 的业务容器,并使用 `kubectl create -f firstpod.yaml` 命令部署 Pod。

相关产品

  • 容器服务Kubernetes版
  • 下一篇
    无影云桌面