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

k8s:离线添加集群节点

本文介绍了在Kubernetes集群中离线添加节点的完整流程。主要内容包括:1)CA证书配置,将Harbor主机的CA证书分别添加到系统信任库、containerd和docker的证书目录;2)节点准备工作,包括拷贝KubeKey工具、配置文件和离线包;3)使用kk命令添加节点,指定配置文件和KubeSphere离线包路径进行部署。关键步骤涉及证书更新、服务重启、目录创建及配置文件编辑等操作,确保新节点能安全访问Harbor仓库并加入集群。

k8s:离线添加集群节点的相关组件安装与升级详见《安装与升级》

证书创建详见《通过HTTPS访问Harbor2.13.1 的配置》

1.CA证书配置

1.1将Harbor主机的CA证书加入node节点的系统信任库

/etc/pki/ca-trust/source/anchors

从master节点拷贝相关的rpm到node节点
 scp ca.crt  root@172.23.123.118:/etc/pki/ca-trust/source/anchors
更新证书
sudo update-ca-trust

1.2将Harbor主机的CA文件复制到节点上的containerd证书文件夹中

#mkdir  /etc/containerd/certs.d
mkdir -p /etc/containerd/certs.d/172.23.123.117:8443

从master节点拷贝相关的rpm到node节点
scp  ca.crt  root@172.23.123.118:/etc/containerd/certs.d/172.23.123.117:8443/
服务重启
systemctl restart containerd
状态
systemctl status containerd

验证

crictl pull 172.23.123.117:8443/kubesphereio/pause:3.9

 

1.3将Harbor主机的CA文件复制到节点上的docker证书文件夹中


您必须先创建相应的文件夹。
mkdir -p /etc/docker/certs.d/172.23.123.117:8443

从master节点拷贝相关的rpm到node节点

scp  ca.crt  root@172.23.123.118:/etc/docker/certs.d/172.23.123.117:8443/

服务重启
systemctl restart docker

验证

docker pull 172.23.123.117:8443/kubesphereio/pause:3.9

 

2.节点准备及部署

2.1拷贝资料

scp kk root@172.23.123.118:/app/KubeSphere/

scp config-sample.yaml root@172.23.123.118:/app/KubeSphere/

scp kubesphere.tar.gz root@172.23.123.118:/app/KubeSphere

2.2KK操作

执行以下命令为 KubeKey 二进制文件 kk 添加执行权限:

sudo chmod +x kk

执行以下命令编辑安装配置文件 config-sample.yaml:

vi config-sample.yaml

 

保存配置文件,执行以下命令开始添加节点:

  ./kk add nodes -f config-sample.yaml -a /app/KubeSphere/kubesphere.tar.gz

注:

1.在app/KubeSphere会多一个kubekey文件夹

2.在/etc/hosts自动增加了两台机器的配置

 ​​​​​​​

各参数含义如下:

参数

含义

./kk

KubeKey 可执行文件,用于部署或管理 Kubernetes + KubeSphere

add nodes

子命令,表示向已有的 Kubernetes 集群中添加新的工作节点(worker nodes)

-f config-sample.yaml

指定配置文件路径,这个 YAML 文件中定义了新节点的 IP、SSH 信息、角色等

-a /app/KubeSphere/kubesphere.tar.gz

指定 KubeSphere 的离线包(打包好的镜像和部署文件),用于在离线环境下安装 KubeSphere 组件

 

http://www.lryc.cn/news/594284.html

相关文章:

  • MySQL—表设计和聚合函数以及正则表达式
  • 【性能测试】性能压测3个阶段+高频面试题回答(详细)
  • 第三章自定义检视面板_创建自定义编辑器类_编辑器操作的撤销与恢复(本章进度3/9)
  • Android 项目中如何在执行 assemble 或 Run 前自动执行 clean 操作?
  • Milvus Dify 学习笔记
  • Unity学习笔记(五)——3DRPG游戏(2)
  • 正点原子stm32F407学习笔记10——输入捕获实验
  • 【no vue no bug】 npm : 无法加载文件 D:\software\nodeJS\node22\npm.ps1
  • ansible awx自动化工具学习准备
  • [学习] 深入理解傅里叶变换:从时域到频域的桥梁
  • 【1】计算机视觉方法(更新)
  • 算法-递推
  • C++ 并发 future, promise和async
  • 设计模式笔记(1)简单工厂模式
  • 基于单片机的自动条幅悬挂机
  • Linux文件系统底层原理:从磁盘物理结构到LBA寻址
  • MySQL锁(一) 概述与分类
  • springboot03-一个简单的SSMP框架
  • MySQL详解三
  • 详解Mysql HashJoin加速原理
  • 乐观锁实现原理笔记
  • LINUX入门(二)QT的安装及运行环境搭建
  • 虚拟机动态IP配置
  • HTTP1-HTTP2-HTTP3简要概述
  • Qt的安装和环境配置
  • Slack介绍(一款专注于企业协作的沟通平台,旨在通过整合聊天、文件共享、任务管理及第三方工具集成,提升团队的工作效率)
  • 【智能协同云图库】第一期:用户管理接口设计与功能实现
  • 统计与大数据分析和数字经济:专业选择指南
  • 数位 dp
  • kafka生产端和消费端的僵尸实例以及解决办法