K8S 源码探秘 之 kubeadm join 执行流程分析_kubernetes node join流程

本文将基于 Kubernetes 1.12 版本,分析 kubeadm  join 的执行流程,希望对读者理解 k8s 有帮助!

关于 init 流程请参考前文: K8S 源码探秘 之 kubeadm init 执行流程分析

二、流程介绍

2.1  首先,上一张整体执行流程图(可以点击看大图!!!):

kubeadm 在执行 join 的过程中,主要包含:配置加载、环境检测、获取和验证kubeconfig、配置本地 kubelet 服务等步骤,其间还穿插着对于当加入节点为 Master 时的一些额外操作。

配置初始化的过程与 init 时基本是一样的,都包含加载系统默认参数、解析和应用用户指定的配置、设置动态配置项(如节点名称、节点 IP 等)以及验证配置有效性等过程,不再赘述。

环境检测的过程与 init 十分类似,只不过检测项目稍有差异,项目列表见 2.2。

获取和验证 kubeconfig 配置在 join 过程中非常关键,之后的配置过程都依赖该步骤的产出。获取 kubeconfig 目前支持三种方式:通过文件加载;通过网络加载;通过 token 从 apiserver 读取。通过文件和网络加载相对比较简单,这里重点介绍第三种也是最常见的 join 方式:通过 token 读取 kubeconfig。首先,kubeadm 会基于 APIServer EndPoint、token-bootstrap-client 用户、kubernetes 集群名以及空的证书数据创建一个不安全的 client,连接 API Server,读取 kube-public/cluster-info ConfigMap,该 ConfigMap 是在 init 的过程中创建好的,匿名即可访问。再读取该 ConfigMap 中保存的 kubeconfig 项、jws-kubeconfig-<token.ID> 项。其中,kubeconfig 项即保存的 kubeconfig 内容,jws-kubeconfig-<token.ID> 项保存的使用该 token 对该 kubeconfig 的签名结果。**kubeadm join 的验签过程即使用用户提供的 token、kube-public/cluster-info 中保存的 kubeconfig 信息进行 jws 签名,将签名结果与 jws-kubeconfig-<token.ID> 项的内容对比,相同则验证通过,认为该 APIServer 可以被信任。**验证通过后,通过该 kubeconfig,可以获取 CA 相关信息,据此就可以创建安全的 client 了。kubeadm 会使用安全的 client 二次获取 kube-public/cluster-info,并与之前获得的比较是否相同,据此验证该 TLS 连接的有效性。

如果 join 的节点角色为 Control Plane Instance,则需要进行一些额外配置。主要过程包括:连接API Server,读取 kube-system/kubeadm-config ConfigMap,据此生成 InitConfiguration,进行 Master 加入相关检查(包括是否使用 Local etcd、是否使用固定 endpoint、是否启用了 self-hosted、证书是否配置正确等),执行 kubeadm init 系列检查,生成证书以及 manifest 文件(kube-apiserver、kube-controller-manager、kube-scheduler)。

配置本地 kubelet 服务无论在 init 还是 join 都是重要的一步。主要过程包括:生成相关配置,主要指 kubelet 运行需要的配置文件;重启 kubelet 服务自动完成 TLS Bootstrap,将 bootstrap-kubelet.conf 转为 kubelet.conf;补充节点的相关属性 Annotation、配置 DynamicKubeletConfig 等。

完成前的操作:如果加入的是 Control Plane Instance,则更新 kubeadm-config ConfigMap,同时给节点添加正确的标签。最后打印出 join 成功描述。

2.2 预检项目

1) 检查执行 init 命令的用户是否为 root,如果不是 root,直接快速失败(fail fast);

2) 检查 /etc/kubernetes/manifests/ 是否为空;

3) 检查 /etc/kubernetes/bootstrap-kubelet.conf 是否不存在;

4) 检查内核是否包含 ipvs 模块;

5) 检查容器运行时,使用 CRI 还是 Docker,如果是 Docker,进一步检查 Docker 服务是否已启动,是否设置了开机自启动;

6) 对于 Linux 系统,会额外检查以下内容:

6.1) 检查以下命令是否存在:crictl、ip、iptables、mount、nsenter、ebtables、ethtool、socat、tc、touch;

6.2) 检查 /proc/sys/net/bridge/bridge-nf-call-iptables、/proc/sys/net/ipv4/ip-forward 内容是否为 1;

6.3) 检查 swap 是否是关闭状态;

7) 检查内核是否被支持,Docker 版本及后端存储 GraphDriver 是否被支持;

对于 Linux 系统,还需检查 OS 版本和 cgroup 支持程度(支持哪些资源的隔离);

最全的Linux教程,Linux从入门到精通

======================

  1. linux从入门到精通(第2版)

  2. Linux系统移植

  3. Linux驱动开发入门与实战

  4. LINUX 系统移植 第2版

  5. Linux开源网络全栈详解 从DPDK到OpenFlow

华为18级工程师呕心沥血撰写3000页Linux学习笔记教程

第一份《Linux从入门到精通》466页

====================

内容简介

====

本书是获得了很多读者好评的Linux经典畅销书**《Linux从入门到精通》的第2版**。本书第1版出版后曾经多次印刷,并被51CTO读书频道评为“最受读者喜爱的原创IT技术图书奖”。本书第﹖版以最新的Ubuntu 12.04为版本,循序渐进地向读者介绍了Linux 的基础应用、系统管理、网络应用、娱乐和办公、程序开发、服务器配置、系统安全等。本书附带1张光盘,内容为本书配套多媒体教学视频。另外,本书还为读者提供了大量的Linux学习资料和Ubuntu安装镜像文件,供读者免费下载。

华为18级工程师呕心沥血撰写3000页Linux学习笔记教程

本书适合广大Linux初中级用户、开源软件爱好者和大专院校的学生阅读,同时也非常适合准备从事Linux平台开发的各类人员。

需要《Linux入门到精通》、《linux系统移植》、《Linux驱动开发入门实战》、《Linux开源网络全栈》电子书籍及教程的工程师朋友们劳烦您转发+评论

详情docs.qq.com/doc/DSmdCdUNwcEJDTXFK

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值