Kubernetes | 起源 | 组件详解

起源

在这里插入图片描述

  • 起源: Kubernetes(常简称为K8s)起源于Google内部的Borg项目,是一个开源的容器编排引擎,于2014年首次对外发布。
    • Google Borg
      Google Borg 是 Google 内部开发和使用的大规模集群管理系统,用于管理和运行数万台服务器上的应用程序和服务。Borg项目的发展经历了以下阶段:

      • 2003年-2004年: Borg项目最初由Google的工程团队开发,旨在解决Google内部服务的管理和部署问题。Borg的设计目标是实现高可靠性、高效率的集群管理,支持多种应用程序和服务的托管和调度。

      • 2005年-2014年: Borg系统在Google内部广泛应用,成为支撑Google各种服务和应用程序的关键基础设施之一。Borg 通过优化资源利用率、提高服务可靠性等方面为Google提供强大的支持。

      • 2014年-至今: 在Borg系统成功运行多年后,Google决定将其集群管理经验和技术开源,于是诞生了Kubernetes项目。Kubernetes 基于Borg的设计思想和经验,在实现上进行改进和优化,以适应更广泛的应用场景和用户群。
        Google Borg项目发展经历从内部研发到开源孵化的过程,为云原生技术的发展和普及做出重要贡献。

    • Kubernetes最初由Google主导开发,后来成为 Cloud Native Computing Foundation(CNCF)孵化项目,得到众多公司和社区的支持和贡献。它的发展迅速,成为容器编排领域的标准。

影响

  • Kubernetes改变了应用程序部署和管理的方式,使得容器化应用程序的部署、扩展、管理和调度变得更加简单和高效。
  • Kubernetes为跨多个主机的容器集群提供了自动化部署、扩展和运维的能力,为构建云原生应用提供重要的基础设施管理能力。

能力

在这里插入图片描述

Kubernetes 是一个用于自动化部署、扩展和管理容器化应用程序的开源平台。
由于 Kubernetes 是在容器级别运行,而非在硬件级别。提供了 PaaS 产品共有的一些普遍适用的功能, 例如部署、扩展、负载均衡,允许用户集成的日志记录、监控和警报方案。
但Kubernetes 不是单体式(monolithic)系统,那些默认解决方案都是可选、可插拔的。 Kubernetes 为构建开发平台提供基础,但在重要的地方保留用户选择权,能有更高的灵活性。
Kubernetes 的主要作用和能力包括:

  1. 容器编排:Kubernetes 可以管理和编排大量容器化应用程序。可以确保应用程序的各个部分在不同容器中正确运行,并且可以管理应用程序间的依赖关系。

  2. 自动化部署和扩展:Kubernetes 根据应用程序需求自动扩展容器的数量,以满足流量增长或负载均衡的需求。还可以轻松地部署新的应用程序版本,而无需中断正在运行的服务。

  3. 服务发现和负载均衡:Kubernetes 可以为应用程序提供内置的服务发现和负载均衡功能。可以轻松地将流量路由到应用程序的不同部分,并确保正常通信。

  4. 自我修复:Kubernetes 可以监控容器的健康状态,并在出现故障时自动重新启动。提高应用程序的可靠性和稳定性。

  5. 密钥管理和配置:Kubernetes 提供安全地管理密钥和配置信息的方式,以确保应用程序在不同环境中的一致性和安全性。

  6. 存储编排:Kubernetes 支持多种存储系统,并提供统一方式来管理应用程序的持久化存储需求。

  7. 扩展性和可定制性:Kubernetes 提供丰富的 API 和插件系统,可以根据需求扩展和定制平台。

能力以外

Kubernetes 不是传统的、包罗万象的 PaaS(平台即服务)系统。

  • 不限制支持的应用程序类型。 Kubernetes 旨在支持极其多种多样的工作负载,包括无状态、有状态和数据处理工作负载。 如果应用程序可以在容器中运行,那么也应该可以在 Kubernetes 上很好地运行。
  • 不部署源代码,也不构建应用程序。 持续集成(CI)、交付和部署(CI/CD)工作流取决于组织的文化和偏好以及技术要求。
  • 不提供应用程序级别服务作为内置服务,例如中间件(例如消息中间件)、 数据处理框架(例如 Spark)、数据库(例如 MySQL)、缓存、集群存储系统 (例如 Ceph)。这样的组件可以在 Kubernetes 上运行,并且可以由运行在 Kubernetes 上的应用程序通过可移植机制(例如开放服务代理)来访问。
  • 不是日志记录、监视或警报系统解决方案。 它集成一些功能作为概念证明,并提供了收集和导出指标的机制。
  • 不提供也不要求配置用的语言、系统:(例如 jsonnet),提供了声明性 API, 该声明性 API 可以由任意形式的声明性规范所构成。
  • 不提供也不采用任何全面的机器配置、维护、管理或自我修复系统
    此外,Kubernetes 不仅仅是一个编排系统,实际上它消除了编排的需要。 编排的技术定义是执行已定义的工作流程:首先执行 A,然后执行 B,再执行 C。 而 Kubernetes 包含一组独立可组合的控制过程,可以持续地将当前状态驱动到所提供的预期状态。 不需要在乎如何从 A 移动到 C,也不需要集中控制,这使得系统更易于使用且功能更强大、 系统更健壮,更为弹性和可扩展。

组件

在这里插入图片描述

  1. kube-apiserver(API Server): 提供Kubernetes API 服务端实现,是集群控制面的前端,负责处理API请求。

  2. etcd(Key-Value Store): 保存整个集群的状态信息,包括节点信息、Pod信息、Service信息等。

  3. kube-scheduler(Scheduler): 负责将新创建的Pod调度到集群中的节点上,根据调度策略选择合适的节点。

  4. kube-controller-manager(Controller Manager): 包含一系列控制器,负责管理集群的状态,如ReplicationController、NodeController等。

  5. kubelet(Kubelet): 运行在每个节点上,负责管理该节点上的Pod生命周期,与容器运行时(如Docker)交互来创建、启动、停止容器。

  6. kube-proxy(Proxy): 负责为Service提供代理和负载均衡功能,实现Kubernetes Service的网络代理和转发。

  7. Container Runtime(容器运行时): 负责运行容器的软件,常见的包括Docker、containerd等。

  8. Pod(Pod): 是Kubernetes最小的调度单元,可以包含一个或多个紧密相关的容器,并共享网络和存储资源。

  9. Service(Service): 定义了一组Pod的逻辑集合,并提供统一的访问入口,可以实现负载均衡、服务发现等功能。

  10. Volume(Volume): 提供容器存储的抽象,可以让容器在生命周期内持久化存储数据。

这些组件共同构成了Kubernetes的核心功能,为用户提供了高效、弹性和可靠的容器编排和管理能力。除了上述核心组件外,Kubernetes还有一些附加组件,如Dashboard、DNS插件、Ingress Controller等,用于提供更丰富的功能和扩展性。

附加组件的介绍:

  1. Dashboard(仪表盘): Kubernetes Dashboard是一个基于Web的用户界面,用于可视化管理Kubernetes集群。它提供了对集群状态、工作负载、服务和存储等资源的实时监控和管理功能,可以方便地查看和操作集群中的各种资源。

  2. DNS插件(DNS Add-on): Kubernetes集群通常会配备一个DNS插件,用于提供服务发现和DNS解析功能。通过DNS插件,用户可以使用域名来访问集群中的服务,而无需关心具体的IP地址。

  3. Ingress Controller(入口控制器): Ingress是Kubernetes中的一种资源对象,用于定义对集群中服务的外部访问规则。Ingress Controller负责实现这些规则,通常通过负载均衡器或反向代理来实现对Ingress资源的路由和流量转发。

  4. 日志插件(Logging Add-on): Kubernetes集群通常会配置日志插件,用于收集、存储和管理Pod的日志信息。常见的日志插件包括Fluentd、Fluent Bit等,它们可以将日志发送到中央日志存储系统,方便用户查看和分析日志数据。

这些附加组件提供丰富的功能和扩展性,可以更好地管理和使用Kubernetes集群。
可根据需求选择合适的组件来增强集群的功能和性能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/450222.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Visual grounding-视觉定位任务介绍

🎀个人主页: https://zhangxiaoshu.blog.csdn.net 📢欢迎大家:关注🔍点赞👍评论📝收藏⭐️,如有错误敬请指正! 💕未来很长,值得我们全力奔赴更美好的生活&…

网络通信另个角度的认识(进程间通信),端口号(为什么要有,和pid的关系,如何封装,和进程的定位原理+对应关系)客户端如何拿到服务端的port

目录 另一个角度认识网络通信 端口号 引入 -- 为什么要有端口号 问题 解决 端口号和pid 举例 介绍 分类 知名端口 注册端口 动态端口 客户端如何知道服务端的端口号 封装端口号 定位原理 进程和端口号的对应关系 数据如何被上层进程读到 另一个角度认识网络…

Node.js安装 (WIndows版本)

一. 下载地址 Node.js 安装包及源码下载地址为:https://nodejs.org/en/download 二. 具体安装步骤 下载对应msi文件后,双击下载后的安装包 点击next,进入下一步 选择安装目录,建议修改到非C盘目录 选择安装环境 点击 I…

docker启动时环境变量不生效(docker打包成镜像后环境变量失效)

前言 因项目需要多处部署,为了部署的方便,于是准备将项目环境打包成docker镜像以便于部署。mq、mysql这些在仓库中都有现成的镜像,虽然java和nginx的也都有,但是不知道当时是怎么想的,就不想搞太多镜像,也…

力扣大厂热门面试算法题 15-17

15. 三数之和,16. 最接近的三数之和,17. 电话号码的字母组合,每题做详细思路梳理,配套Python&Java双语代码, 2024.03.11 可通过leetcode所有测试用例。 目录 15. 三数之和 解题思路 完整代码 Java Python ​…

29.基于SSM实现的少儿编程网上报名系统(项目 + 论文PPT)

项目介绍 随着计算机的不断发展,已经融入到我们生活工作的每一个领域中,给我们的生活工作带来了很多的便利,因此,希望可以通过该系统的开发也能使少儿编程网上报名系统实现信息化管理,减轻人的负担,提高工作…

申请选择商家转账到零钱流程怎样的

商家转账到零钱是什么? 【商家转账到零钱】可以说是【企业付款到零钱】的升级版,商家转账到零钱可以为商户提供同时向多个用户微信零钱转账的能力,支持分销返佣、佣金报酬、企业报销、企业补贴、服务款项、采购货款等自动向用户转账的场景。…

伦敦金交易市场的参与者有哪些?

伦敦金交易市场,作为全球最大的黄金交易市场之一,吸引了众多的参与者。这些参与者来自不同的背景和角色,每个人都在这个市场中发挥着重要的作用。 首先,我们不得不提到的是市场的核心参与者——交易商。交易商是市场上最活跃的群体…

FTP,SFTP,FTPS,SSL,TSL简介,区别,联系,使用场景说明

文章目录 简介FTPFTPSSFTP加密场景选择FTPS还是SFTPFTP、SFTP、FTPS区别、联系和具体使用场景如何使用FTP、SFTP和FTPSSSLTLSSSL和TLS区别和联系,以及使用场景SSL和TLS技术上的区别一些问题隐式的TLS(FTPS/SSL)或者显式的TLS(FTPS…

【Python】新手入门学习:什么是python解释器,它的作用是什么?

【Python】新手入门学习:什么是python解释器,它的作用是什么? 🌈 个人主页:高斯小哥 🔥 高质量专栏:Matplotlib之旅:零基础精通数据可视化、Python基础【高质量合集】、PyTorch零基…

STM32CubeMX学习笔记19——SD卡(SDIO接口)

1、简介 1.1 SD卡简介 很多单片机系统都需要大容量存储设备,以存储数据(常用的有U盘、FLASH芯片、SD卡等),比较而言SD卡是单片机大容量外部存储的首选,只需要少数几个IO口即可外扩一个容量从几十M到几十G的&#xff…

前端实现 查询包含分页 以及封装table表格 上手即用!

表格组件是 element plus 中的table 又经过了一层封装 封装的table代码在最底下 <div class"box2"><el-radio-group v-model"radio" style"margin-bottom: 16px"><el-radio-button label"1">类型1</el-radio…

vue3 uniapp 项目初始化集成配置【开箱即用】

https://gitee.com/charrie/vue3-uniapp-init 技术说明 采用vue3viteuniapp技术栈&#xff0c;setup语法糖编码方式引入unocss量子化样式引擎&#xff0c;动态css不用自己写样式&#xff0c;引用class即可&#xff0c;降低代码体积全局请求入口已封装&#xff0c;使用时自己封…

易基因: WGBS+ChIP-seq揭示食管癌的细胞类型和癌症特异性表观遗传调控|Genome Biol

大家好&#xff0c;这里是专注表观组学十余年&#xff0c;领跑多组学科研服务的易基因。 食管癌是一种常见的恶性肿瘤&#xff0c;有两种亚型&#xff1a;鳞状细胞癌&#xff08;squamous cell carcinoma&#xff0c;ESCC&#xff09;和腺癌&#xff08;adenocarcinoma&#x…

【C++】string类(介绍、常用接口)

&#x1f308;个人主页&#xff1a;秦jh__https://blog.csdn.net/qinjh_?spm1010.2135.3001.5343&#x1f525; 系列专栏&#xff1a;http://t.csdnimg.cn/eCa5z 目录 string类的常用接口说明 string类对象的常见构造 ​编辑 string字符串的遍历&#xff08;迭代器&#xf…

力扣刷题Days12--104二叉树最大深度(js)

目录 1&#xff0c;题目 2&#xff0c;代码 2.1深度优先遍历--递归思想 2.2-0广度优先搜索--错误版 2.2广度优先搜索 3&#xff0c;学习与总结 3.1二叉树的复习 3.2array常用函数复习 1&#xff0c;题目 给定一个二叉树 root &#xff0c;返回其最大深度。二叉树的 最大…

解决Iterm2升级后遇到“Stashed changes“的问题

&#xff1c;&#xff1c;&#xff1c;&#xff1c;&#xff1c;&#xff1c;&#xff1c; Updated upstream ...... &#xff1e;&#xff1e;&#xff1e;&#xff1e;&#xff1e;&#xff1e;&#xff1e; Stashed changes冲突标记符的代码如题&#xff0c;最近有升级Item2…

鸿蒙原生应用元服务开发-WebGL网页图形库开发接口说明

一、场景介绍 WebGL主要帮助开发者在前端开发中完成图形图像的相关处理&#xff0c;比如绘制彩色图形等。目前该功能仅支持使用兼容JS的类Web开发范式开发。 二、接口说明 表1 WebGL主要接口列表 本文参考引用HarmonyOS官方开发文档&#xff0c;基于API9。

RStudio更换R语言版本

今天下载R语言用于读取.xlsx文件的readxl包时&#xff0c;RStudio提示该包是使用R-4.3.3版本构建&#xff0c;而我现在使用的是R-4.3.2版本&#xff0c;所以需要升级一下R语言版本&#xff0c;这里先下载最新版本的R语言&#xff0c; 下载地址&#xff1a;The Comprehensive R…

Early if-conversion - 优化阅读笔记

Early if-conversion 用于对于没有很多可预测指令的乱序CPU。目标是消除可能误预测的条件分支。 来自分支两侧的指令都会被推测性地执行&#xff0c;并使用 cmov 指令选择结果。 // SSAIfConv 类在确定可能的情况下&#xff0c;对SSA形式的机器码执行if-conversion。该类不包…