k8s介绍

一、前言

   Kubernetes(通常简称为 K8s)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序,它提供了丰富的功能使得用户能够轻松地管理大规模的容器集群,包括自动化部署和扩展、服务发现和负载均衡、存储编排、自我修复、密钥管理和安全、水平扩展和滚动更新,以下就来简单的介绍一下k8s的组件和功能

二、组件

etcd:用于存储Kubernetes集群的配置数据、状态和元数据。etcd是Kubernetes的后端数据库,负责保存整个集群的状态信息

kube-apiserver:k8s集群的管理接口,所有对k8s集群的操作都通过API服务器进行处理,包括创建、更新和删除资源对象的请求

kube-controller-manage:k8s集群的控制器,集成了多个控制器,根据所需的状态进行调节,确保集群的期望状态与实际状态一致,其中包含Replication Controller、node Controller、Service Controller、Endpoint Controller、Namespace Controller、Service Account & Token Controller

kube-schduler:k8s集群的调度器,负责将新创建的Pod分配到集群中的节点上。它考虑诸如资源需求、硬件约束、数据本地性等因素,以确保最佳的Pod调度决策,其中的策略有优选策略、预选策略

kubelet:工作节点的监控器,负责管理该节点上的容器和Pod。它与API服务器通信,确保节点上的Pod按照规范运行,并向API服务器报告节点和Pod的状态

kube-proxy:工作节点的负载均衡器,负责在集群内部进行网络代理和负载均衡。它维护网络规则,允许Pod之间和外部网络之间的通信,并确保服务的可访问性,当节点网络发生变更时,负责更改iptables规则

三、工作流程

在了解工作流程前先来提前了解一下k8s的watch机制,watch机制是什么呢,watch"机制是指通过API Server监视资源对象的变化,这种机制对于实时了解集群中资源的状态变化非常有用,在Kubernetes中,每个组件都可以通过API Server上的restful API订阅资源对象的变更。这些组件可以通过HTTP长连接来监听资源对象的变更,一旦资源对象发生变化,API Server会向订阅者发送通知。这种方式可以用来实现各种功能,比如实时监控、自动伸缩、事件驱动等

创建pod

1.客户端使用kubectl调用kube-apiserver集群管理接口创建pod

2.kube-apiserver将资源变更信息写入etcd中存储

3.apiserver接收etcd的回调事件

4.apiserver将事件推送给订阅者kube-schduler

5.kube-schduler根据预选策略或者优选策略将pod调度到相应node节点的事件发送给apiserver

6.kube-apiserver将资源变更信息写入etcd中

7.apiserver接收etcd的回调事件

8.apiserver将事件推送给订阅者kubelet

9.kubelet调用cri启动相应的容器

10.kubele将pod状态通过kube-apiserver写入到etcd中

创建replicaset

1.客户端使用kubectl调用kube-apiserver集群管理接口创建replicaset控制器

2.kube-apiserver将信息写入etcd中存储

3.apiserver接收etcd的回调事件

4.apiserver将事件推送给订阅者kubeletkube-contorller-manage

5.kube-contorller-manage根据定义的信息通过replication controller创建rs,然后根据rs中的期望pod副本数量发送给apiserver创建pod的事件

6.kube-apiserver将资源变更信息写入etcd中

7.apiserver接收etcd的回调事件

8.apiserver将事件推送给订阅者kube-schduler

9.kube-schduler根据预选策略或者优选策略将pod调度到相应node节点的事件发送给apiserver

10.kube-apiserver将资源变更信息写入etcd中

11.apiserver将事件推送给订阅者kubelet

12.kubelet调用cri启动相应的容器

13.kubele将pod状态通过kube-apiserver写入到etcd中

四、资源隔离

namespace

Kubernetes中的命名空间(Namespace)是一种逻辑隔离机制,用于将集群中的资源划分为不同的虚拟群组,以实现多租户、多环境或多项目的资源隔离和管理,不同命名空间中的资源对象彼此之间相互隔离,互不影响。例如,Pod、Service、Deployment等资源对象都可以属于特定的命名空间,这样它们之间的名称可以相同,但彼此不会相互冲突,但某些资源对象是全局的,不属于任何特定的命名空间,例如节点(Node)、存储类(StorageClass)、持久卷(PersistentVolume)等。这些资源对象可以被所有命名空间中的资源对象共享和使用

Linux命名空间,Kubernetes利用Linux命名空间来实现容器之间的隔离,每个容器都运行在独立的命名空间中,包括PID(进程ID)、网络、文件系统、用户等。这意味着每个容器拥有自己的进程树、网络栈、文件系统视图和用户空间,从而避免了容器之间的干扰和资源冲突,但是内核还是共用的宿主机内核

linux命名空间解析:容器的创建是通过linux命名空间实现的,容器,其实是一种特殊的进程,在使用容器的时候,实际上还是在当前主机上创建一个应用进程,只不过在创建这些进程时,Docker 为它们加上了各种各样的 Namespace 参数,从而使得在同一系统上运行的进程之间能够拥有各自独立的视图和隔离的环境,因为是宿主机上的进程,所以多个容器之间使用的还是同一个宿主机的内核。Linux Namespace 主要用于以下几个方面的资源隔离

PID 命名空间(PID Namespace):PID 命名空间使得每个命名空间内的进程拥有独立的进程树。一个进程在其所属的命名空间内看到的进程编号(PID)与其他命名空间内的进程编号是不同的,这样就实现了进程隔离

网络命名空间(Network Namespace):网络命名空间提供了一套独立的网络栈,使得每个命名空间内的进程拥有自己独立的网络接口、IP 地址、路由表和防火墙规则等。这种隔离机制使得不同网络命名空间内的进程可以拥有独立的网络环境,从而实现了网络隔离

挂载命名空间(Mount Namespace):挂载命名空间为每个命名空间提供了独立的文件系统挂载点,使得在不同命名空间内的进程能够拥有不同的文件系统视图。这种隔离机制使得每个命名空间内的进程可以拥有独立的文件系统环境,从而实现了文件系统隔离

UTS 命名空间(UTS Namespace):UTS 命名空间提供了独立的主机名和域名标识符,使得在不同命名空间内的进程拥有独立的主机名和域名标识符。这种隔离机制使得每个命名空间内的进程可以拥有独立的系统标识符,从而实现了系统标识符隔离

IPC 命名空间(IPC Namespace):IPC 命名空间提供了独立的进程间通信(IPC)资源,包括消息队列、信号量和共享内存等,使得在不同命名空间内的进程之间的 IPC 资源不会相互干扰,从而实现了进程间通信资源的隔离

cgroup

控制组(Cgroups)是Linux内核提供的一种资源管理机制,用于限制和管理进程组的资源消耗。Kubernetes利用Cgroups来限制容器对CPU、内存、磁盘等资源的使用。通过为容器设置资源配额和限制,可以确保集群中的容器在资源利用方面得到合理的调度和管理

Kubernetes中的Resource Quota资源配额机制允许集群管理员为命名空间设置资源使用的上限。资源配额可以限制CPU、内存、存储等资源的使用量,确保各个命名空间内的资源消耗得到合理控制,防止某个应用程序占用过多资源而影响其他应用程序的正常运行,实际上还是通过resource quota的配置参数转化底层cgroup的配置去实现资源的限制

五、iptables与ipvs

iptables 在 Kubernetes 集群中扮演了重要角色,用于实现服务发现、负载均衡、网络策略、服务代理等功能。通过使用 iptables,Kubernetes 可以灵活地管理和控制集群中的网络流量,从而保障集群的安全性、稳定性和可靠性

服务发现和负载均衡:Kubernetes 中的 Service 对象提供了一种抽象,用于将一组具有相同标签的 Pod 组合成一个逻辑服务。为了实现服务的访问和负载均衡,Kubernetes 通过 iptables 规则将请求转发到 Service 对应的 Pod 上,从而实现服务发现和负载均衡的功能

网络策略:Kubernetes 中的 NetworkPolicy 对象用于定义 Pod 之间和 Pod 与外部网络之间的网络访问策略。为了实现这些策略,Kubernetes 使用 iptables 来过滤和控制流量,根据网络策略规则来允许或阻止流量的传输

服务代理:Kubernetes 中的代理组件,比如 kube-proxy,负责将服务的请求转发到后端的 Pod 上。这些代理组件通常使用 iptables 来设置转发规则,从而实现服务代理的功能

Pod 网络:Kubernetes 中的容器网络插件(CNI)负责为 Pod 分配 IP 地址,并实现 Pod 之间的通信。一些 CNI 插件使用 iptables 来实现网络地址转换(NAT)等功能,以确保 Pod 可以正常访问外部网络

iptables和ipvs都可以作为k8s的负载均衡组件,但是在大规模集群中使用ipvs会比使用iptables性能更好,因为iptables是防火墙,在大规模集群中,iptables的规则量会很大,iptables又是使用链表的方式匹配,所以使用iptables作为负载均衡组件的话,需要匹配大量的规则,这会导致性能大量的消耗,而ipvs作为专门的负载均衡组件,支持多种负载均衡调度算法,如轮询(RR)、加权轮询(WRR)、最小连接数(LC)等。这些调度算法能够更加智能地分配流量到后端服务器,从而提高了整体的负载均衡性能,还有一点就是 IPVS 是基于内核的实现,可以利用 Linux 内核提供的各种优化和功能来提高性能和可扩展性。而 iptables 是基于用户空间的实现,性能和可扩展性相对较低

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

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

相关文章

漫威争锋Marvel Rivals怎么搜索 锁区怎么搜 游戏搜不到怎么办

即将问世的《漫威争锋》(Marvel Rivals)作为一款万众期待的PvP射击游戏新星,荣耀携手漫威官方网站共同推出。定档5月11日清晨9时,封闭Alpha测试阶段将正式揭开序幕,持续时间长达十天之久。在此首轮测试窗口&#xff0c…

一个开源即时通讯源码

一个开源即时通讯源码 目前已经含服务端、PC、移动端即时通讯解决方案,主要包含以下内容。 服务端简介 不要被客户端迷惑了,真正值钱的是服务端, 服务是采用Java语言开发,基于spring cloud微服务体系开发的一套即时通讯服务端。…

栈结构(c语言)

1.栈的概念 栈:一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶,另一端称为栈底。栈中的数据元素遵守后进先出LIFO(Last In First Out)的原则。 压栈&am…

STM32的ADC详解

ADC即模拟数字转换器,通常用于将外部的模拟量信号转换为数字信号。STM32的ADC是12位逐次逼近型的模拟数字转换器,最大可以计数到4095,有18个通道,16个外部通道和2个内部通道。 ADC框图 ADC的功能框图可以分为七个部分&#xff1a…

记一次springboot jpa更新复杂几何类型报错Only simple geometries should be used

问题: 更新数据时, 几何字段MultiPolygon类型时报错; java.lang.IllegalStateException: Only simple geometries should be used 几何字段Point类型时不报错; 新增时字段存在MultiPolygon不报错。 查看日志可知,…

vscode 使用正则搜索

ctrl c 复制,内容如下: Vue3简介创建Vue3工程Vue3核心语法路由pinia组件通信其它 APIVue3新组件

Go 单元测试完全指南(一)- 基本测试流程

为什么写单元测试? 关于测试,有一张很经典的图,如下: 说明: 测试类型成本速度频率E2E 测试高慢低集成测试中中中单元测试低快高 也就是说,单元测试是最快、最便宜的测试方式。这不难理解,单元…

Baidu Comate:让编码实现无限可能

目录 1 背景介绍2 快速入门2.1 智能推荐功能2.2 智能生成功能2.2.1 智能注释2.2.2 智能生成2.2.3 智能调优2.2.4 代码解释 3 高兼容性4 即刻体验 1 背景介绍 Baidu Comate(智能代码助手)是基于文心大模型,结合百度积累多年的编程现场大数据和…

【MySQL数据库】丨一文详解 JdbcTemplate(Spring中的CRUD)

前言 JdbcTemplate 是 Spring框架 中提供的一个对象,用于简化JDBC操作。它使得数据库操作变得更为简单和方便,大大提高了开发效率。 文章目录 前言为何要使用JdbcTemplate在JdbcTemplate中执行SQL语句的方法大致分为3类:案例代码 JdbcTemplat…

word 毕业论文格式调整

添加页眉页脚 页眉 首先在页面上端页眉区域双击,即可出现“页眉和页脚”设置页面: 页眉左右两端对齐 如果想要页眉页脚左右两端对齐,可以选择添加三栏页眉,然后将中间那一栏删除,即可自动实现左右两端对齐&#x…

Linux 操作系统TCP、UDP

1、TCP服务器编写流程 头文件&#xff1a; #include <sys/socket.h> 1.1 创建套接字 函数原型&#xff1a; int socket(int domain, int type, int protocol); 参数&#xff1a; domain: 网域 AF_INET &#xff1a; IPv4 AF_INET6 &a…

fswatch工具:跟踪Linux中的文件和目录更改

fswatch是一个跨平台的文件更改监视器&#xff0c;当指定文件或目录的内容被更改或修改时&#xff0c;它会收到通知警报。 fswatch在不同的操作系统上执行多种类型的监视器&#xff0c;例如&#xff1a; 基于 Apple OS X 的文件系统事件 API 构建的监视器。基于kqueue的监视器…

WPF之DataGird应用

1&#xff0c;DataGrid相关属性 GridLinesVisibility&#xff1a;DataGrid网格线是否显示或者显示的方式。HorizontalGridLinesBrush&#xff1a;水平网格线画刷。VerticalGridLinesBrush&#xff1a;垂直网格线画刷。HorizontalScrollBarVisibility&#xff1a;水平滚动条可见…

ASP.NET MVC 如何使用 Form Authentication?

前言 .NET 的 Form Authentication 是一种基于表单的简单且灵活的身份验证机制&#xff0c;用户通过输入用户名和密码来登录应用程序&#xff0c;并且通过配置来控制用户访问权限。 在使用 Form Authentication 时&#xff0c;我们需要在 web.config 文件中配置身份验证和授权…

Spring Cloud Consul 4.1.1

该项目通过自动配置和绑定到 Spring 环境和其他 Spring 编程模型习惯用法&#xff0c;为 Spring Boot 应用程序提供 Consul 集成。通过一些简单的注释&#xff0c;您可以快速启用和配置应用程序内的常见模式&#xff0c;并使用基于 Consul 的组件构建大型分布式系统。提供的模式…

Spark云计算平台Databricks使用,第一个Spark应用程序WordCount

1 上传文件 上传words.txt文件&#xff1a;Spark云计算平台Databricks使用&#xff0c;上传文件-CSDN博客 上传的文件的路径是/FileStore/tables/words.txt&#xff0c;保存在AWS的S3 hello world hello hadoop hello world hello databricks hadoop hive hbase yarn spark …

利用BACnet分布式IO控制器优化Niagara楼宇自动化系统

在智能建筑领域&#xff0c;随着物联网技术的飞速发展&#xff0c;如何实现高效、灵活且安全的楼宇自动化控制成为了行业关注的焦点。BACnet IP分布式远程I/O模块&#xff0c;作为这一领域的创新成果&#xff0c;正逐渐成为连接智能建筑各子系统的关键桥梁&#xff0c;尤其在与…

springboot -多数据源管理方案

多数据源的配置有多种方式 方式一 、依赖dataSource的配置 1.建立多数据源配置 spring:# 数据源配置datasource:pdm:driver-class-name: oracle.jdbc.driver.OracleDriverjdbc-url: jdbc:oracle:thin:10.216.xxx.xxx:3000:orclusername: cfpdmpassword: capecapp:driver-cla…

走进CHEN MEI HUA的设计哲学:书写东方女性力量与态度的时尚篇章

在时尚的舞台中央&#xff0c;品牌不止是商品&#xff0c;更是故事的讲述者、文化的传承者。CHEN MEI HUA&#xff0c;一个源自中国上海的高端女装品牌&#xff0c;以其独特的设计理念及文化内核&#xff0c;成为了时尚界一颗耀眼的明珠。今天&#xff0c;让我们一起走进CMH的世…

如何安装ElasticSearch及相关件

一、简介 ElasticSearch是什么&#xff1f; elasticsearch简写es&#xff0c;es是一个高扩展、开源的全文检索和分析引擎&#xff0c;它可以准实时地快速存储、搜索、分析海量的数据。 ElasticSearch 插件 elasticsearch-head是一款专门针对于elasticsearch的客户端工具&am…