【Kubernetes】神乎其技的K8s到底是什么,为什么被越来越多人使用

news2024/11/24 19:45:29

在这里插入图片描述

🚀欢迎来到本文🚀
🍉个人简介:陈童学哦,目前学习C/C++、算法、Python、Java等方向,一个正在慢慢前行的普通人。
🏀系列专栏:陈童学的日记
💡其他专栏:C++STL,感兴趣的小伙伴可以看看。
🎁希望各位→点赞👍 + 收藏⭐️ + 留言📝 ​
⛱️万物从心起,心动则万物动🏄‍♂️


前言

Kubernetes,也被简称为K8s(因为k和s之间有8个字母),是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。它提供了一个高度可靠且可扩展的平台,能够简化容器化应用程序的部署和管理工作。

K8sd的简介

K8s是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。它提供了一个强大的平台,帮助开发人员和运维团队更轻松地管理和运行容器化应用。

K8s的核心概念包括以下几个方面:

  • 1.Pod(容器组):Pod是Kubernetes的最小调度单元,它由一个或多个容器组成,共享相同的网络和存储资源。Pod提供了容器之间的通信和资源共享机制

  • 2.Deployment(部署):Deployment是用于定义和管理Pod的副本数量的资源对象。它可以控制Pod的创建、更新和删除过程,实现应用程序的自动化部署和扩展

  • 3.Service(服务):Service是一种抽象,用于定义一组Pod的访问方式。它为Pod提供了稳定的网络端点,并实现了负载均衡和服务发现功能。

  • 4.Namespace(命名空间):Namespace用于划分Kubernetes集群中不同团队或项目的资源。它提供了隔离和命名标识的机制,使得不同的团队可以在同一个集群上独立地管理和运行应用程序。

  • 5.Volume(存储卷):Volume是用于持久化存储数据的抽象。它可以将外部存储系统挂载到Pod中,使得数据可以在容器之间进行共享和持久化

  • 6.ConfigMap和Secret:ConfigMap用于存储应用程序的配置信息,而Secret用于存储敏感的密钥和凭证信息。它们可以被挂载到Pod中,供应用程序使用。

  • 7.StatefulSet(有状态集合):StatefulSet是用于管理有状态应用程序(如数据库)的资源对象。它为每个Pod分配唯一的标识和稳定的网络标识,确保数据的持久性和顺序访问


  除了上述核心概念外,Kubernetes还提供了丰富的功能和工具,如自动伸缩、滚动升级、日志和监控、安全性和认证等。同时,Kubernetes还支持多种云平台和容器运行时,如AWS、Azure、Docker等。

  总之,Kubernetes是一个功能强大的容器编排平台,提供了丰富的功能和抽象,使得开发人员和运维团队能够更轻松地管理和运行容器化应用程序。它的设计目标是提供一个开放、可移植和可扩展的平台,使得应用程序能够在不同的环境中高效地运行

K8s的由来

  K8s的由来可以追溯到Google内部的容器集群管理系统,该系统被称为Borg。在Google内部,Borg系统用于管理数以百万计的容器化应用程序,实现高效的资源利用和应用程序的自动化部署、扩展和管理。

  由于Borg系统在Google内部取得了巨大的成功,Google决定将其开源,并于2014年发布了Kubernetes项目。Kubernetes的目标是为云原生应用提供一个开放、可移植和可扩展的平台,使开发者能够更轻松地构建、部署和管理容器化应用程序。

  Kubernetes在开源社区中迅速获得了广泛的关注和采用,并成为容器编排领域的事实标准。它得到了全球各个组织和公司的支持和贡献,包括Google、Red Hat、Microsoft、IBM等。

  Kubernetes的设计受到了Borg系统的启发,也进行了一系列的改进和扩展,以适应不同环境和需求。它提供了丰富的功能,如自动化部署、弹性伸缩、服务发现、负载均衡、存储管理、故障恢复等,使得开发者能够更好地管理和运行容器化应用。

  总之,Kubernetes的由来可以追溯到Google内部的Borg系统,它的开源发布使得容器编排技术得到了广泛的推广和应用。

K8s的特点和功能

在这里插入图片描述

Kubernetes的主要特点和功能包括:

  • 1.自动化部署和扩展:Kubernetes可以自动化地部署和扩展应用程序,根据资源需求进行自动调度,确保应用程序的高可用性和性能。

  • 2.服务发现和负载均衡:Kubernetes提供了内置的服务发现机制,使得应用程序可以轻松地进行服务间的通信。同时,它还提供了负载均衡功能,确保流量被均匀地分配到不同的服务实例上。

  • 3.存储管理:Kubernetes支持各种存储选项,包括本地存储、网络存储和云存储。它可以自动管理存储卷,并将其挂载到容器中,使得应用程序可以持久化地存储数据。

  • 4.自动故障恢复:Kubernetes可以自动监测容器和节点的健康状态,并在发生故障时进行自动修复。它支持容器的重新启动、节点的替换和应用程序的滚动升级,以确保应用程序的持续可用性。

  • 5.配置和密钥管理:Kubernetes提供了集中式的配置和密钥管理机制,使得应用程序的配置和敏感信息可以被安全地管理和更新。

  • 6.扩展性和可插拔性:Kubernetes具有高度可扩展的架构,支持水平扩展和垂直扩展。同时,它还提供了丰富的API和插件机制,可以与其他工具和服务进行集成。

Kubernetes是一个功能强大的容器编排平台,可以帮助用户轻松地管理和运行容器化应用程序。它提供了一系列的功能和特性,使得应用程序的部署、扩展、管理和监控变得更加简单和高效。

K8s的组件

在这里插入图片描述
一个Kubernetes集群主要是由控制节点(master)、工作节点(node)构成,每个节点上都会安装不同的组件。
master:集群的控制平面,负责集群的决策
node:集群的数据平面,负责为容器提供运行环境


以下是Kubernetes的一些核心组件:

  • API Server:Kubernetes的控制面板,提供了集群的API入口,用于管理和监控整个集群。

  • etcd:Kubernetes的数据存储,用于存储集群的配置信息和状态,以及存储应用程序的元数据。

  • Scheduler:Kubernetes的调度器,用于将应用程序部署到集群中的节点上,并根据资源需求和节点负载等因素进行自动调度。

  • Controller Manager:Kubernetes的控制器管理器,用于管理各种控制器,如ReplicaSet、Deployment、StatefulSet等,以保证应用程序的高可用性和可扩展性。

  • Kubelet:Kubernetes的节点代理,用于管理节点上的容器和Pod,以及与Master节点通信和同步状态。

  • Container Runtime:Kubernetes支持多种容器运行时,如Docker、CRI-O等,用于创建和管理容器。

  • kube-proxy:Kubernetes的网络代理,用于在集群内部的Pod之间提供网络代理和负载均衡服务。

  • Ingress Controller:用于实现HTTP和HTTPS等应用程序层协议的负载均衡和反向代理。

这些组件共同构成了Kubernetes的完整架构,可以实现容器化应用程序的高可用性、自动化部署和管理等功能。

K8s的架构

  Kubernetes的架构是一个分布式系统,由多个核心组件组成,每个组件负责不同的功能。下面是Kubernetes的架构详解:
1.Master节点:Master节点是Kubernetes集群的控制平面,负责管理和监控整个集群。它包括以下组件:

  • 1.API Server(API服务器):提供集群的API入口,用于接收和处理来自用户和其他组件的请求。

  • 2.etcd(数据存储):用于存储集群的配置信息和状态数据,以及持久化存储应用程序的元数据。

  • 3.Scheduler(调度器):根据资源需求和策略,将应用程序Pod调度到合适的节点上运行。

  • 4.Controller Manager(控制器管理器):管理各种控制器,如ReplicaSet、Deployment等,以保证应用程序的高可用性和可扩展性。

2.Node节点:Node节点是集群中的工作节点,负责运行应用程序的容器。它包括以下组件:

  • 1.Kubelet(节点代理):负责管理节点上的Pod和容器,与Master节点通信并同步状态。

  • 2.Container Runtime(容器运行时):负责创建和管理容器,如Docker、CRI-O等。

  • 3.kube-proxy(网络代理):负责在集群内部的Pod之间提供网络代理和负载均衡服务。

3.插件和附加组件:Kubernetes还支持各种插件和附加组件,用于扩展集群的功能和能力。一些常见的插件和附加组件包括:

  • 1.Network Plugin(网络插件):用于实现集群内部和集群外部的网络通信,如Flannel、Calico等。

  • 2.DNS(域名系统):提供集群内部的服务发现和命名解析,使得应用程序可以通过名称进行访问。

  • 3.Ingress Controller(入口控制器):用于实现HTTP和HTTPS等应用程序层协议的负载均衡和反向代理。

  • 4.Dashboard(仪表盘):提供一个Web界面,用于可视化地管理和监控集群。

在这里插入图片描述
Kubernetes的架构利用分布式系统的原理和设计,实现了容器化应用程序的自动化管理和部署。Master节点负责整个集群的控制和管理,而Node节点负责运行应用程序的容器。通过这样的架构,Kubernetes能够提供高可用性、可扩展性和弹性的容器平台,帮助用户更好地管理和运行容器化应用程序。

如果本文对大家有所帮助的话,还望各位能给我点赞、收藏并评论一下,感谢各位💕!!! 另如果大家有什么疑问或者建议的话,欢迎评论区留言。

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

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

相关文章

户外骨传导耳机推荐,盘点最适合户外佩戴的五款耳机

现在天气越来越暖和了,很多人选择外出徒步、越野或者骑行,在这些活动中往往都会搭配一个骨传导耳机,来让运动过程变得更加有趣。在选购骨传导耳机时,人们通常会考虑音质、舒适性、价格等因素,为了让大家选到更适合自己…

Kafka API与SpringBoot调用

文章目录 首先需要命令行创建一个名为cities的主题,并且创建该主题的订阅者。 1、使用Kafka原生API1.1、创建spring工程1.2、创建发布者1.3、对生产者的优化1.4、批量发送消息1.5、创建消费者组1.6 消费者同步手动提交1.7、消费者异步手动提交1.8、消费者同异步手动…

yolov5目标检测多线程Qt界面

上一篇文章&#xff1a;yolov5目标检测多线程C部署 V1 基本功能实现 mainwindow.h #pragma once#include <iostream>#include <QMainWindow> #include <QFileDialog> #include <QThread>#include <opencv2/opencv.hpp>#include "yolov5.…

phpspreadsheet excel导入导出

单个sheet页Excel2003版最大行数是65536行。Excel2007开始的版本最大行数是1048576行。Excel2003的最大列数是256列&#xff0c;2007以上版本是16384列。 xlswriter xlswriter - PHP 高性能 Excel 扩展&#xff0c;功能类似phpspreadsheet。它能够处理非常大的文件&#xff0…

056B R包ENMeval教程-基于R包ENMeval对MaxEnt模型优化调参和结果评价制图(更新)

056B-1 资料下载 056B-2 R包ENMeval在MaxEnt模型优化调参中的经典案例解读 056B-3 R软件和R包ENMeval工具包安装 056B-4 R软件和R包ENMeval安装报错解决办法 056B-5 环境数据格式要求和处理流程 056B-6 分布数据格式要求和处理流程 056B-7 基于R包ENMeval对MaxEnt模型优化…

12.pod生命周期和存储卷

文章目录 pod生命周期pod启动阶段故障排除步骤&#xff1a; 存储卷emptyDir存储卷 hostPath存储卷nfs共享存储卷总结&#xff1a; pod生命周期 pod启动阶段 一般来说&#xff0c;pod 这个过程包含以下几个步骤&#xff1a; 调度到某台 node 上。kubernetes 根据一定的优先级算…

【C#】静默安装、SQL SERVER静默安装等

可以通过cmd命令行来执行&#xff0c;也可以通过代码来执行&#xff0c;一般都需要管理员权限运行 代码 /// <summary>/// 静默安装/// </summary>/// <param name"fileName">安装文件路径</param>/// <param name"arguments"…

Dubbo 2.7.0 CompletableFuture 异步

了解Java中Future演进历史的同学应该知道&#xff0c;Dubbo 2.6.x及之前版本中使用的Future是在java 5中引入的&#xff0c;所以存在以上一些功能设计上的问题&#xff0c;而在java 8中引入的CompletableFuture进一步丰富了Future接口&#xff0c;很好的解决了这些问题。 Dubb…

小内存嵌入式设备软件的差分升级设计(学习)

摘要 提出一种改进HDiffPatch算法并在复旦微单片机上实现小内存差分升级的方案&#xff0c;即使用单片机内的Flash空间替代算法占用的RAM空间&#xff0c;从而减少算法对单片机RAM空间的需求&#xff0c;以满足小内存微处理器的差分升级&#xff0c;同时对算法内存分配释放函数…

HashMap源码探究之底“库”看穿

前言&#xff1a; 本次的源码探究会以jdk1.7和jdk1.8对比进行探究二者在HashMap实现上有的差异性&#xff0c;除此之外&#xff0c;还会简单介绍HashMap的hash算法的设计细节、jdk1.8中HashMap添加功能的整个流程、什么情况下会树化等源码设计知识。 一、HashMap介绍 HashMap…

SpringBoot3数据库集成

标签&#xff1a;Jdbc.Druid.Mybatis.Plus&#xff1b; 一、简介 项目工程中&#xff0c;集成数据库实现对数据的增晒改查管理&#xff0c;是最基础的能力&#xff0c;而对于这个功能的实现&#xff0c;其组件选型也非常丰富&#xff1b; 通过如下几个组件来实现数据库的整合…

Spring Cloud 智慧工地源码(PC端+移动端)项目平台、监管平台、大数据平台

智慧工地源码 智慧工地云平台源码 智慧建筑源码 “智慧工地”是利用物联网、人工智能、云计算、大数据、移动互联网等新一代信息技术&#xff0c;彻底改变传统建筑施工现场参建各方现场管理的交互方式、工作方式和管理模式&#xff0c;实现对人、机、料、法、环的全方位实时监…

uniapp开发公众号,微信开发者工具进行本地调试

每次修改完内容都需要发行之后&#xff0c;再查看效果&#xff0c;很麻烦 &#xff01;&#xff01;&#xff01; 下述方法&#xff0c;可以一边在uniapp中修改内容&#xff0c;一边在微信开发者工具进行本地调试 修改hosts文件 在最后边添加如下内容 修改前端开发服务端口 …

Android 第一行代码学习 -- 聊天界面小练习

前言&#xff1a;最近在学习安卓&#xff0c;阅读入门书籍第一行代码&#xff0c;以后更新的知识可能大部分都会和安卓有关。 实现聊天界面 1.编写主界面 个人觉得界面编写刚开始学可能看着很乱&#xff0c;但是其中最重要的是层次&#xff0c;看懂了其中的层次&#xff0c;就…

论element-ui表格的合并行和列(巨细节)

论element-ui表格的合并行和列 0、前言 ​ 作为一个后端来写前端属实是痛苦、讲真的、刚开始我是真不想用饿了么的这个合并行和列、因为太语焉不详了、看着头疼、后来发现好像我没得选、只好硬着头皮上了。 1、element - ui 的合并行和列代码 效果图&#xff1a; 代码&…

SpringSecurity环境搭建

AOP思想&#xff1a;面向切面编程 导入依赖 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation&quo…

【算法题】螺旋矩阵II (求解n阶Z形矩阵)

一、问题的提出 n阶Z形矩阵的特点是按照之(Z)字形的方式排列元素。n阶Z形矩阵是指矩阵的大小为nn&#xff0c;其中n为正整数。 题目描述 一个 n 行 n 列的螺旋(Z形)矩阵如图1所示&#xff0c;观察并找出填数规律。 图1 7行7列和8行8列的螺旋(Z形)矩阵 现在给出矩阵大小 n&…

异步电机模型预测转矩控制MPTC关键技术(1、一拍延迟补偿)

导读&#xff1a;本期文章主要介绍异步电机模型预测转矩控制MPTC中的一拍延迟补偿的内容。先进性一拍延迟补偿原理的介绍&#xff0c;之后进行仿真验证补偿的有效性。 如果需要文章中的仿真模型&#xff0c;关注微信公众号&#xff1a;浅谈电机控制&#xff0c;留言获取。 一…

Vue输入框或者选择框无效,或者有延迟

问题剖析 使用Vue这种成熟好用的框架&#xff0c;一般出现奇奇怪怪的问题都是因为操作不当导致的&#xff0c;例如没有合理调用组件、组件位置不正确、没有合理定义组件或者变量、样式使用不当等等... 解决方案 如果你也出现了输入框输入东西&#xff0c;但是没有效果…

Qt扫盲-Qt Model/View 理论总结 [下篇]

Qt Model/View 理论总结 [下篇] 一、处理I tem view 中的选择1. 概念1. 当前项目和已选项目 2. 使用选择 model1. 选择项目2. 读取选区状态3. 更新选区4. 选择 model 中的所有项 二、创建新 model1. 设计一个 model2. 只读示例 model1. model 的尺寸2. model 头和数据 3. 可编辑…