当前位置: 首页 > news >正文

K8S学习指南(60)-K8S源代码走读之API-Server

文章目录

    • API Server 的代码结构
    • API Server 的核心逻辑
      • 1. 请求处理流程
        • 1.1 HTTP 请求处理
        • 1.2 认证和授权
        • 1.3 API 版本处理
        • 1.4 资源路由
        • 1.5 资源处理
        • 1.6 响应生成
      • 2. 存储层
        • 2.1 存储接口定义
        • 2.2 存储实现
    • 二次开发扩展点
      • 1. 插件机制
        • 1.1 插件注册
        • 1.2 插件实现
      • 2. 自定义资源定义(CRD)
        • 2.1 CRD 定义
        • 2.2 CRD 控制器
      • 3. Admission 控制器
        • 3.1 Admission 控制器定义
        • 3.2 Admission 控制器实现
      • 4. 扩展 API Server 功能
        • 4.1 功能扩展配置
    • 结语

Kubernetes 源代码存放在 GitHub 上,你可以通过以下链接获取:Kubernetes GitHub 仓库。API Server 相关的代码位于 pkg/apiserverpkg/mastercmd/kube-apiserver 等目录中。

  • pkg/apiserver: 包含 API Server 的核心逻辑,如请求处理、认证、授权等。
  • pkg/master: 包含 Master 组件,其中 API Server 是 Master 的一个组成部分。
  • cmd/kube-apiserver: 包含 API Server 的入口文件,以及启动 API Server 所需的配置和参数。

API Server 的代码结构

pkg/apiserver 目录下,API Server 的代码结构主要分为以下几个模块:

  • apis: 包含了定义 Kubernetes API 资源的代码。
  • auth: 处理认证和授权的逻辑。
  • storage: 提供资源的存储和操作。
  • handlers: 包含了请求处理的具体实现。
  • options: 包含了 API Server 的配置选项。

API Server 的核心逻辑

1. 请求处理流程

1.1 HTTP 请求处理
  • 代码位置: pkg/apiserver/server.go
  • 主要功能: API Server 接收到来自客户端的 HTTP 请求。
1.2 认证和授权
  • 代码位置: pkg/auth
  • 主要功能: 对请求进行认证和授权,验证请求是否合法。
1.3 API 版本处理
  • 代码位置: pkg/server/request/request.go
  • 主要功能: 根据请求中的 API 版本信息,选择正确的版本进行处理。
1.4 资源路由
  • 代码位置: pkg/server/request/request.go
  • 主要功能: 根据请求的路径(例如 /api/v1/pods)确定请求的资源类型,并将请求路由到相应的资源处理器。
1.5 资源处理
  • 代码位置: pkg/server/handlers/
  • 主要功能: 调用相应的资源处理器对请求进行处理,包括读取、创建、更新和删除等操作。
1.6 响应生成
  • 代码位置: pkg/server/responsewriter/responsewriter.go
  • 主要功能: 根据处理结果生成 HTTP 响应返回给客户端。

2. 存储层

2.1 存储接口定义
  • 代码位置: pkg/storage
  • 主要功能: 定义了与后端数据存储(如 etcd)交互的存储接口。
2.2 存储实现
  • 代码位置: pkg/storage/etcd
  • 主要功能: 实现了 etcd 存储接口,用于与 etcd 进行交互,实现对资源的持久化存储。

二次开发扩展点

1. 插件机制

1.1 插件注册
  • 代码位置: pkg/master/plugin.go
  • 主要功能: 插件机制允许用户注册和使用插件,如认证插件、授权插件等。
1.2 插件实现
  • 代码位置: pkg/auth/plugins/
  • 主要功能: 用户可以实现自定义的插件,通过注册到 API Server 中,以扩展认证和授权逻辑。

2. 自定义资源定义(CRD)

2.1 CRD 定义
  • 代码位置: pkg/apis/
  • 主要功能: 用户可以定义自己的 API 资源类型,扩展 Kubernetes 中的资源模型。
2.2 CRD 控制器
  • 代码位置: pkg/controller/customresource/
  • 主要功能: 用户可以编写控制器来处理自定义资源的生命周期,定义其行为和状态。

3. Admission 控制器

3.1 Admission 控制器定义
  • 代码位置: pkg/admission/
  • 主要功能: 用户可以定义 Admission 控制器,拦截和修改资源的创建、修改、删除等操作。
3.2 Admission 控制器实现
  • 代码位置: pkg/admission/plugins/
  • 主要功能: 用户可以实现自定义的 Admission 控制器,通过注册到 API Server 中,以实现对资源的拦截和修改。

4. 扩展 API Server 功能

4.1 功能扩展配置
  • 代码位置: cmd/kube-apiserver/app/server.go
  • 主要功能: 用户可以通过修改 kube-apiserver 的启动参数或配置文件,为 API Server 添加额外的功能。

结语

以上是 Kubernetes API Server 部分的一个简要走读。为了深入理解和学习,建议直接查阅 Kubernetes 源代码,并深入阅读相关文档。希望这个指导对你进行 Kubernetes API Server 的源代码走读提供了帮助。

相关文章:

K8S学习指南(60)-K8S源代码走读之API-Server

文章目录 API Server 的代码结构API Server 的核心逻辑1. 请求处理流程1.1 HTTP 请求处理1.2 认证和授权1.3 API 版本处理1.4 资源路由1.5 资源处理1.6 响应生成 2. 存储层2.1 存储接口定义2.2 存储实现 二次开发扩展点1. 插件机制1.1 插件注册1.2 插件实现 2. 自定义资源定义&…...

基于深度学习的交通标志图像分类识别系统

温馨提示:文末有 CSDN 平台官方提供的学长 QQ 名片 :) 1. 项目简介 本文详细探讨了一基于深度学习的交通标志图像识别系统。采用TensorFlow和Keras框架,利用卷积神经网络(CNN)进行模型训练和预测,并引入VGG16迁移学习…...

使用uni-app editor富文本组件设置富文本内容及解决@Ready先于onload执行,无法获取后端接口数据的问题

开始使用富文本组件editor时,不知如何调用相关API设置富文本内容和获取内容,本文将举例详解 目录 一.了解editor组件的常用属性及相关API 1.属性常用说明 2.富文本相关API说明 1)editorContext 2) editorContext.setContents…...

Spring高手之路-Spring事务的传播机制(行为、特性)

目录 含义 七种事务传播机制 1.REQUIRED(默认) 2.REQUIRES_NEW 3.SUPPORTS 4.NOT_SUPPORTED 5.MANDATORY 6.NEVER 7.NESTED 含义 Spring事务的传播机制是指在多个事务方法相互调用时,如何处理这些事务的传播行为。对应七种事务传播行为…...

简易机器学习笔记(八)关于经典的图像分类问题-常见经典神经网络LeNet

前言 图像分类是根据图像的语义信息对不同类别图像进行区分,是计算机视觉的核心,是物体检测、图像分割、物体跟踪、行为分析、人脸识别等其他高层次视觉任务的基础。图像分类在许多领域都有着广泛的应用,如:安防领域的人脸识别和…...

pytest conftest通过fixture实现变量共享

conftest.py scope"module" 只对当前执行的python文件 作用 pytest.fixture(scope"module") def global_variable():my_dict {}yield my_dict test_case7.py import pytestlist1 []def test_case001(global_variable):data1 123global_variable.u…...

系列五、搭建Naco(集群版)

一、搭建Naco(集群版) 1.1、前置说明 (1)64位Red Hat7 Linux 系统; (2)64位JDK1.8;备注:如果没有安装JDK,请参考【系列二、Linux中安装JDK】 (3&…...

JavaScript中alert、prompt 和 confirm区别及使用【通俗易懂】

✨前言✨   本篇文章主要在于,让我们看几个与用户交互的函数:alert,prompt 和confirm的使用及区别 🍒欢迎点赞 👍 收藏 ⭐留言评论 📝私信必回哟😁 🍒博主将持续更新学习记录收获&…...

【GoLang入门教程】Go语言几种标准库介绍(四)

编程语言的未来? 文章目录 编程语言的未来?前言几种库fmt库 (格式化操作)关键函数:示例 Go库标准库第三方库示例 html库(HTML 转义及模板系统)主要功能:示例 总结专栏集锦写在最后 前言 上一篇,我们介绍了debug、enco…...

面试算法:快速排序

题目 快速排序是一种非常高效的算法,从其名字可以看出这种排序算法最大的特点就是快。当表现良好时,快速排序的速度比其他主要对手(如归并排序)快2~3倍。 分析 快速排序的基本思想是分治法,排序过程如下…...

航空业数字化展翅高飞,开源网安专业服务保驾护航

​某知名航空公司是中国首批民营航空公司之一,运营国内外航线200多条,也是国内民航最高客座率的航空公司之一。在数字化发展中,该航空公司以数据驱动决策,通过精细化管理、数字创新和模式优化等方式,实现了精准营销和个…...

SpringBoot学习(三)-员工管理系统开发(重在理解)

注:此为笔者学习狂神说SpringBoot的笔记,其中包含个人的笔记和理解,仅做学习笔记之用,更多详细资讯请出门左拐B站:狂神说!!! 本文是基于狂神老师SpringBoot教程中的员工管理系统从0到1的实践和理解。该系统应用SpringB…...

2 Windows网络编程

1 基础概念 1.1 socket概念 Socket 的原意是“插座”,在计算机通信领域,socket 被翻译为“套接字”,它是计算机之间进行通信的一种约定或一种方式。Socket本质上是一个抽象层,它是一组用于网络通信的API,包括了一系列…...

uniapp选择android非图片文件的方案踩坑记录

这个简单的问题我遇到下面6大坑,原始需求是选择app如android的excel然后读取到页面并上传表格数据json 先看看效果 uniapp 选择app excel文件读取 1.uniapp自带不支持 uniapp选择图片和视频非常方便自带已经支持可以直接上传和读取 但是选择word excel的时候就出现…...

前端发开的性能优化 请求级:请求前(资源预加载和预读取)

预加载 预加载:是优化网页性能的重要技术,其目的就是在页面加载过程中先提前请求和获取相关的资源信息,减少用户的等待时间,提高用户的体验性。预加载的操作可以尝试去解决一些类似于减少首次内容渲染的时间,提升关键资…...

B01、类加载子系统-02

JVM架构图-英文版 中文版见下图: 1、概述类的加载器及类加载过程 1.1、类加载子系统的作用 类加载器子系统负责从文件系统或者网络中加载Class文件,class文件在文件开头有特定的文件标识。ClassLoader只负责class文件的加载,至于它是否可以运行,则由Execution Engi…...

用PHP搭建一个绘画API

【腾讯云AI绘画】用PHP搭建一个绘画API 大家好!今天我要给大家推荐的是如何用PHP搭建一个绘画API,让你的网站或应用瞬间拥有强大的绘画能力!无论你是想要让用户在网页上绘制自己的创意,还是想要实现自动绘画生成特效,这…...

西安人民检察院 | OLED翻页查询一体机

产品:55寸OLED柔性屏 项目时间:2023年12月 项目地点:西安 在2023年12月,西安人民检察院引入了OLED翻页查询一体机,为来访者提供了一种全新的信息查询方式。 这款一体机采用55寸OLED柔性屏,具有高清晰度、…...

superset利用mysql物化视图解决不同数据授权需要写好几次中文别名的问题

背景 在使用superset时,给不同的人授权不同的数据,需要不同的数据源,可视化字段希望是中文,所以导致不同的人需要都需要去改表的字段,因此引入视图,将视图中字段名称设置为中文 原表数据 select * from …...

输入输出流

1.输入输出流 输入/输出流类:iostream---------i input(输入) o output(输出) stream:流 iostream: istream类:输入流类-------------cin:输入流类的对象 ostream类…...

Opencv中的addweighted函数

一.addweighted函数作用 addweighted()是OpenCV库中用于图像处理的函数,主要功能是将两个输入图像(尺寸和类型相同)按照指定的权重进行加权叠加(图像融合),并添加一个标量值&#x…...

Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility

Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility 1. 实验室环境1.1 实验室环境1.2 小测试 2. The Endor System2.1 部署应用2.2 检查现有策略 3. Cilium 策略实体3.1 创建 allow-all 网络策略3.2 在 Hubble CLI 中验证网络策略源3.3 …...

相机Camera日志分析之三十一:高通Camx HAL十种流程基础分析关键字汇总(后续持续更新中)

【关注我,后续持续新增专题博文,谢谢!!!】 上一篇我们讲了:有对最普通的场景进行各个日志注释讲解,但相机场景太多,日志差异也巨大。后面将展示各种场景下的日志。 通过notepad++打开场景下的日志,通过下列分类关键字搜索,即可清晰的分析不同场景的相机运行流程差异…...

工业自动化时代的精准装配革新:迁移科技3D视觉系统如何重塑机器人定位装配

AI3D视觉的工业赋能者 迁移科技成立于2017年,作为行业领先的3D工业相机及视觉系统供应商,累计完成数亿元融资。其核心技术覆盖硬件设计、算法优化及软件集成,通过稳定、易用、高回报的AI3D视觉系统,为汽车、新能源、金属制造等行…...

【学习笔记】深入理解Java虚拟机学习笔记——第4章 虚拟机性能监控,故障处理工具

第2章 虚拟机性能监控,故障处理工具 4.1 概述 略 4.2 基础故障处理工具 4.2.1 jps:虚拟机进程状况工具 命令:jps [options] [hostid] 功能:本地虚拟机进程显示进程ID(与ps相同),可同时显示主类&#x…...

LINUX 69 FTP 客服管理系统 man 5 /etc/vsftpd/vsftpd.conf

FTP 客服管理系统 实现kefu123登录,不允许匿名访问,kefu只能访问/data/kefu目录,不能查看其他目录 创建账号密码 useradd kefu echo 123|passwd -stdin kefu [rootcode caozx26420]# echo 123|passwd --stdin kefu 更改用户 kefu 的密码…...

Git 3天2K星标:Datawhale 的 Happy-LLM 项目介绍(附教程)

引言 在人工智能飞速发展的今天,大语言模型(Large Language Models, LLMs)已成为技术领域的焦点。从智能写作到代码生成,LLM 的应用场景不断扩展,深刻改变了我们的工作和生活方式。然而,理解这些模型的内部…...

数学建模-滑翔伞伞翼面积的设计,运动状态计算和优化 !

我们考虑滑翔伞的伞翼面积设计问题以及运动状态描述。滑翔伞的性能主要取决于伞翼面积、气动特性以及飞行员的重量。我们的目标是建立数学模型来描述滑翔伞的运动状态,并优化伞翼面积的设计。 一、问题分析 滑翔伞在飞行过程中受到重力、升力和阻力的作用。升力和阻力与伞翼面…...

pycharm 设置环境出错

pycharm 设置环境出错 pycharm 新建项目,设置虚拟环境,出错 pycharm 出错 Cannot open Local Failed to start [powershell.exe, -NoExit, -ExecutionPolicy, Bypass, -File, C:\Program Files\JetBrains\PyCharm 2024.1.3\plugins\terminal\shell-int…...

热烈祝贺埃文科技正式加入可信数据空间发展联盟

2025年4月29日,在福州举办的第八届数字中国建设峰会“可信数据空间分论坛”上,可信数据空间发展联盟正式宣告成立。国家数据局党组书记、局长刘烈宏出席并致辞,强调该联盟是推进全国一体化数据市场建设的关键抓手。 郑州埃文科技有限公司&am…...