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集群。
可根据需求选择合适的组件来增强集群的功能和性能。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

每天一个数据分析题(一百九十九)

指标体系由各种不同类型指标构成,以下关于各个指标类型的描述正确的是() A. 一般业务方最关心的指标被认为是根指标。 B. 根指标与最常用的派生指标结合,生成组合指标。 C. 根指标与最常用的维度取值相结合,生成组合…

Jmeter+Ant+Git/SVN+Jenkins实现持续集成接口测试,一文精通(二)

前言 上篇内容已经介绍接口测试流程以及了解如何用jmeter接口测试,本篇将介绍如何在实战中应用 一、Jmeter接口关联 1.使用正则表达式实现接口关联(可以作用于任意值) 如果说一个请求里面有多次请求服务器。 2.使用Jsonpath表达式实现接口关…

c++ primer plus笔记 第十八章 探讨c++新标准

复习前面的内容: 1.auto,可以自动识别auto本身在这种语境下是什么类型 2.decltype,让一个变量的类型和另外一个变量的类型相同 decltype(x) y;//让y的类型和x的类型相同 如何理解? decltype是一个关键词,其作用是检查括号内的…

Android studio虚拟调试出现“我的APP keeps stopping”问题

问题如图: 遇到这种情况,一看代码,也没有报错呀,怎么不能运行呢?不要慌!我们一步一步来。 1、查看Logcat日志 在Android Studio中查看Logcat窗口,可以获取应用程序崩溃时的详细错误信息&…

【触想智能】工业触摸显示器在户外使用需要注意哪些问题?

工业显示器是智能制造领域应用比较广泛的电子产品,它广泛应用于工厂产线以及各种配套设备,在很大程度上提升了工厂的生产效率。 工业显示器按触摸方式分,可以分为工业触摸显示器和非触摸工业显示器两种;按使用环境分,又可以分为室…

初识网络编程

目录 前言: 1.网络编程: 1.1概述: 1.2网络编程的层次: 1.2.1应用层: 1.2.1.1这是网络编程中最接近用户的层次。 1.2.1.2包含了许多应用协议,如HTTP(Web浏览器与服务器通信)、FTP(文件传输)、SMTP(电子…

几何变换 - 图像的缩放、翻转、仿射变换、透视等

1、前言 图像的几何变换是指改变图像的几何结构,大小、形状等等,让图像呈现出具备缩放、翻转、映射和透视的效果 图像的几何变换都比较复杂,计算也很复杂。 例如仿射变换,像素点的位置和灰度值都需要变换。 数字图像处理中利用后向传播的方法,将像素点变换后的位置通过…

腾讯云和阿里云4核8G云服务器多少钱一年和1个月费用对比

4核8G云服务器多少钱一年?阿里云ECS服务器u1价格955.58元一年,腾讯云轻量4核8G12M带宽价格是646元15个月,阿腾云atengyun.com整理4核8G云服务器价格表,包括一年费用和1个月收费明细: 云服务器4核8G配置收费价格 阿里…

使用VScode避坑指南

在安装VScode的过程中,总是不可避免地产生一些意想不到的坑,下面我就分类来讲讲可以避开的那些坑: MSSQL相关 安装插件 在安装完mssql插件后,其实还需要安装一个sql tool service才能用,这个插件呢,是在…

案例分析篇08:Web架构设计相关20个考点(1~6)(2024年软考高级系统架构设计师冲刺知识点总结系列文章)

专栏系列文章推荐: 2024高级系统架构设计师备考资料(高频考点&真题&经验)https://blog.csdn.net/seeker1994/category_12601310.html 【历年案例分析真题考点汇总】与【专栏文章案例分析高频考点目录】(2024年软考高级系统架构设计师冲刺知识点总结-案例分析篇-…

【基于arm linux c语言编程MODBUS rs485 RTU模式】

要在ARM Linux上使用C语言读取Modbus协议的串口数据,需要按照以下步骤进行操作: 打开串口设备:使用open()函数打开串口设备文件,例如"/dev/ttyUSB0"。可以使用O_RDWR标志表示读写模式打开串口。 配置串口参数&#xf…

golang学习随便记16-反射

为什么需要反射 下面的例子中编写一个 Sprint 函数,只有1个参数(类型不定),返回和 fmt.Fprintf 类似的格式化后的字符串。实现方法大致为:如果参数类型本身实现了 String() 方法,那调用 String() 方法即可…

【备忘录】kafka常用命令维护

kafka指令备忘录 单个Topic扩容 sh bin/kafka-topics.sh --bootstrap-server broker_host:port --alter --topic test_create_topic1 --partitions 4 批量扩容 将所有正则表达式匹配到的Topic分区扩容到4个 sh bin/kafka-topics.sh --topic “.*?” --bootstrap-server 172.23…

钡铼技术R40工业路由器4G WiFi一体,适用于各类工业场景

钡铼技术R40工业路由器是一款集4G网络连接和WiFi功能于一体的先进设备,旨在满足各类工业场景对稳定、高速网络连接的需求。作为一家致力于工业互联网解决方案的领先厂商,钡铼技术致力于为工业企业提供可靠的网络设备,以支持其数字化转型和智能…

【AIGC调研系列】copilot在自动化测试脚本中的实际应用效果

GitHub Copilot在自动化测试脚本中的实际应用效果是多方面的。首先,Copilot能够帮助开发者快速编写测试用例代码,并简化测试流程[5]。这表明Copilot在自动化测试方面具有一定的优势,能够提高开发效率和测试质量。 然而,也有证据指…

HTML5 CSS3常见新特性

HTML新特性 新增特性&#xff1a; 语义化标签&#xff1a;&#xff0c;如<header>、<footer>、<nav>、<article>、<section>等&#xff0c;能够更准确地描述网页结构视频和音频&#xff1a;添加了<video>和<audio>标签&#xff0c…

OSI七层模型TCP四层模型横向对比

OSI 理论模型&#xff08;Open Systems Interconnection Model&#xff09;和TCP/IP模型 七层每一层对应英文 应用层&#xff08;Application Layer&#xff09; 表示层&#xff08;Presentation Layer&#xff09; 会话层&#xff08;Session Layer&#xff09; 传输层&#x…

Java实现递归删除菜单和删除目录及目录下所有文件

目录 一、什么是递归&#xff1f; 二、示例分析 一、什么是递归&#xff1f; 递归调用是一种特殊的嵌套调用&#xff0c;是某个函数调用自己或者是调用其他函数后再次调用自己的&#xff0c;只要函数之间互相调用能产生循环的则一定是递归调用&#xff0c;递归调用一种解决方…

蓝牙通讯——连接你我的无线魔法

引言&#xff1a; 在当今科技高速发展的时代&#xff0c;无线通讯技术已成为我们生活中不可或缺的一部分。其中&#xff0c;蓝牙通讯作为一种广泛应用的无线通讯技术&#xff0c;以其便捷、高效的特点&#xff0c;深入到了我们的日常生活与工作之中。那么&#xff0c;蓝牙通讯究…

Spring Data访问Elasticsearch(一)----Elasticsearch客户端

Spring Data访问Elasticsearch&#xff08;一&#xff09;----Elasticsearch客户端 一、命令式Rest客户端二、反应式&#xff08;Reactive&#xff09;Rest客户端三、客户端配置3.1 客户端配置回调3.1.1 底层Elasticsearch RestClient的配置:3.1.2 底层Elasticsearch RestClien…