首页 > 其他分享 >【kubernetes入门到精通】Kubernetes架构分析介绍篇「入门篇」

【kubernetes入门到精通】Kubernetes架构分析介绍篇「入门篇」

时间:2022-10-22 14:31:27浏览次数:66  
标签:Kubernetes kubernetes 提供 调度 入门篇 集群 Borg 负责


意志的出现不是对愿望的否定,而是把愿望合并和提升到一个更高的意识水平上。——罗洛·梅


官方网站

​Kubernetes中文官方网站​

​Kubernetes英文官方网站​


Kubernetes基本介绍

Kubernetes最初源于谷歌内部的Borg,提供了面向应用的容器集群部署和管理系统。Kubernetes的目标旨在消除编排物理/虚拟计算,网络和存储基础设施的负担,并使应用程序运营商和开发人员完全将重点放在以容器为中心的原语上进行自助运营。Kubernetes也提供稳定、兼容的基础(平台),用于构建定制化的workflows和更高级的自动化任务。

Kubernetes具备完善的集群管理能力,包括多层次的安全防护和准入机制、多租户应用支撑能力、透明的服务注册和服务发现机制、内建负载均衡器、故障发现和自我修复能力、服务滚动升级和在线扩容、可扩展的资源自动调度机制、多粒度的资源配额管理能力。Kubernetes 还提供完善的管理工具,涵盖开发、部署测试、运维监控等各个环节。

什么是Borg

Borg是谷歌内部的大规模集群管理系统,负责对谷歌内部很多核心服务的调度和管理。Borg的目的是让用户能够不必操心资源管理的问题,让他们专注于自己的核心业务,并且做到跨多个数据中心的资源利用率最大化。

Borg主要由BorgMaster、Borglet、borgcfg和Scheduler组成,如下图所示

【kubernetes入门到精通】Kubernetes架构分析介绍篇「入门篇」_设计理念

  • BorgMaster是整个集群的大脑,负责维护整个集群的状态,并将数据持久化到Paxos存储中;
  • Scheduer负责任务的调度,根据应用的特点将其调度到具体的机器上去;
  • Borglet负责真正运行任务(在容器中);
  • borgcfg是Borg的命令行工具,用于跟Borg系统交互,一般通过一个配置文件来提交任务。

Kubernetes基本结构

Kubernetes借鉴了Borg的设计理念,⽐如:Pod、Service、Label和单Pod单IP等。Kubernetes的整体架构跟Borg⾮常像,如下图所示。

【kubernetes入门到精通】Kubernetes架构分析介绍篇「入门篇」_集群管理_02

Kubernetes核心组件
  1. etcd保存了整个集群的状态;
  2. apiserver提供了资源操作的唯一入口,并提供认证、授权、访问控制、API注册和发现等机制;
  3. controller manager负责维护集群的状态,比如故障检测、自动扩展、滚动更新等;
  4. scheduler负责资源的调度,按照预定的调度策略将Pod调度到相应的机器上;
  5. kubelet负责维护容器的生命周期,同时也负责Volume(CVI)和网络(CNI)的管理;
  6. Container runtime负责镜像管理以及Pod和容器的真正运行(CRI);
  7. kube-proxy负责为Service提供cluster内部的服务发现和负载均衡;

除了核⼼组件,还有⼀些推荐的插件,其中有的已经成为 CNCF 中的托管项⽬:

  1. CoreDNS负责为整个集群提供DNS服务
  2. Ingress Controller 为服务提供外⽹⼊⼝
  3. Prometheus 提供资源监控
  4. Dashboard 提供 GUI
  5. Federation 提供跨可⽤区的集群

Kubernetes内部结构图

Kubernetes 的架构设计以及组件之间的通信协议

【kubernetes入门到精通】Kubernetes架构分析介绍篇「入门篇」_服务发现_03

kubernetes外部结构图

【kubernetes入门到精通】Kubernetes架构分析介绍篇「入门篇」_设计理念_04

Master架构

【kubernetes入门到精通】Kubernetes架构分析介绍篇「入门篇」_服务发现_05

Node架构

【kubernetes入门到精通】Kubernetes架构分析介绍篇「入门篇」_服务发现_06

分层架构

Kubernetes 设计理念和功能其实就是⼀个类似 Linux 的分层架构,如下图所示。

【kubernetes入门到精通】Kubernetes架构分析介绍篇「入门篇」_服务发现_07

  • 核⼼层:Kubernetes 最核⼼的功能,对外提供 API 构建⾼层的应⽤,对内提供插件式应⽤执⾏环境
  • 应⽤层:部署(⽆状态应⽤、有状态应⽤、批处理任务、集群应⽤等)和路由- (服务发现、DNS 解析等)、Service Mesh(部分位于应⽤层)
  • 管理层:系统度量(如基础设施、容器和⽹络的度量),⾃动化(如⾃动扩展、动态 Provision 等)以及策略管理(RBAC、Quota、PSP、NetworkPolicy 等)、Service Mesh(部分位于管理层)
  • 接⼝层:kubectl 命令⾏⼯具、客户端 SDK 以及集群联邦
  • ⽣态系统:在接⼝层之上的庞⼤容器集群管理调度的⽣态系统,可以划分为两个范畴
  • Kubernetes 外部:⽇志、监控、配置管理、CI/CD、Workflow、FaaS、OTS 应⽤、ChatOps、GitOps、SecOps 等
  • Kubernetes 内部:CRI、CNI、CSI、镜像仓库、Cloud Provider、集群⾃身的配置和管理等

标签:Kubernetes,kubernetes,提供,调度,入门篇,集群,Borg,负责
From: https://blog.51cto.com/alex4dream/5785827

相关文章

  • 14. Kubernetes - Job 和 CronJob
    JobJob负责处理任务,主要为仅执行一次的任务,它保证批处理任务的一个或多个Pod成功结束。Job的资源清单如下所示:apiVersion:batch/v1kind:Jobmetadata:name:j......
  • Kubernetes---Volume存储卷
    一、Volume存储卷简介Volume将容器中的指定数据和容器解耦,并将数据存储到指定的位置,不同的存储卷功能不一样,如果是基于网络存储的存储卷可以可实现容器间的数据共享和......
  • Kubernetes dashboard安装配置
    查看podkubectlgetpo-nkubernetes-dashboard-owideNAMEREADYSTATUSRESTARTSAGEIPNODENOMINATEDNODEREADINESSGATESdashboard-metrics-scraper-6b4884c9......
  • Web基础配置篇(十七): Kubernetes dashboard安装配置
    https://zhuanlan.zhihu.com/p/91731765如果已经有失败的安装过程,先删除掉失败dashboard的安装:kubectldelete-fkubernetes-dashboard.yaml......
  • 【Kubernetes】K8s笔记(十一):Ingress 集群进出流量总管
    目录0.Ingress解决了什么问题1.IngressController2.指定IngressClass使用多个IngressController3.使用YAML描述Ingress/IngressClass3.1Ingress3.2Ingr......
  • Kubernetes 1.25 正式发布,多方面重大突破
    容器默认的镜像仓库从http://k8s.gcr.io迁移到了http://registry.k8s.io,目前两个镜像仓库都是可用的,未来会逐渐迁移到后者。国内用户可以尝试镜像的同步地址http://k8......
  • 13. Kubernetes - DaemonSet
    DaemonSet通过控制器名称可以看出:Daemon,就是用来部署守护进程的。DaemonSet用于在每个Kubernetes节点中将守护进程的副本作为后台进程运行,说白了就是在每个节点部署一......
  • Kubernetes镜像
    https://developer.aliyun.com/mirror/kubernetes点击查看代码apt-getupdate&&apt-getinstall-yapt-transport-httpscurlhttps://mirrors.aliyun.com/kubernete......
  • Kubernetes的镜像地址为:https://repo.huaweicloud.com/kubernetes/
    1、备份/etc/apt/sources.list.d/kubernetes.list文件:cp/etc/apt/sources.list.d/kubernetes.list/etc/apt/sources.list.d/kubernetes.list.bak2、修改/etc/apt/sour......
  • KubernetesK8s CKA认证实战(完整版)BAT大厂基于K8s构建企业容器云平台
    KubernetesK8sCKA认证实战(完整版)BAT大厂基于K8s构建企业容器云平台 ​Kubernetes认证管理员是CNCF的一项具有挑战性的考试。与许多其他认证不同,这是一个实操的考试。......