Kubeasz快速部署k8s混合架构集群

#作者:曹付江

文章目录

前言

混合架构集群这里是指集群中既有linux amd64架构机器,也有linux arm64架构机器;这里只记录一个简单的操作说明,实际操作注意风险。

1.部署思路

  1. 先选定一台amd64架构的机器做"amd64部署机",使用它先部署amd64架构的集群
  2. 选一台arm64架构的机器做"arm64部署机",复制amd64部署机的/etc/kubeasz目录文件(除去目录中的bin、down子目录),然后重新下载arm64架构的二进制和镜像,然后添加arm64节点到原有集群即可

2.操作步骤

2.1.假设已经正常部署了amd64架构的三节点集群

2.2.在"amd64部署机"

目录 /etc/kubeasz 中移除子目录 bin 和 down,然后把整体/etc/kubeasz 目录复制到"arm64部署机"

复制代码
# 登录amd64部署机
cd /etc/kubeasz; mv bin down /tmp/; scp -r /etc/kubeasz root@{_ip_arm64}:/etc/
# 复制完成后找回 bin 和 down 子目录
mv /tmp/bin /etc/kubeasz/; mv /tmp/down /etc/kubeasz/

2.3.登录"arm64部署机",执行下载,其他准备工作

复制代码
cd /etc/kubeasz
# 下载基础部分
./ezdown -D
# 下载额外部分(如有)
./ezdown -X ...
# 运行部署容器
./ezdown -S
# 配置机器ssh免密码登录,集群所有节点都免密,包括待新增arm64节点
ssh-copy-id xx.xx.xx.xx
ssh-copy-id ...
# 复制kubeconfig
mkdir /root/.kube/; cp clusters/default/kubectl.kubeconfig /root/.kube/config

2.4.添加arm64新节点到集群

复制代码
source ~/.bashrc
# 添加新节点 x.x.x.x
dk ezctl add-node default x.x.x.x

2.5.验证

复制代码
$ kubectl get node -owide
NAME           STATUS   ROLES    AGE    VERSION   INTERNAL-IP    EXTERNAL-IP   OS-IMAGE             KERNEL-VERSION       CONTAINER-RUNTIME
k8s-x.x.x-19   Ready    master   5d8h   v1.33.1   x.x.x.19   <none>        Ubuntu 20.04.4 LTS   5.4.0-122-generic    containerd://2.1.1
k8s-x.x.x-90   Ready    node     5d8h   v1.33.1   x.x.x.90   <none>        Ubuntu 22.04.5 LTS   5.15.0-134-generic   containerd://2.1.1
k8s-x.x.x-91   Ready    node     5d8h   v1.33.1   x.x.x.91   <none>        Ubuntu 22.04.5 LTS   5.15.0-134-generic   containerd://2.1.1
k8s-x.x.x-93   Ready    node     79s    v1.33.1   x.x.x.93   <none>        Ubuntu 22.04.5 LTS   5.15.0-140-generic   containerd://2.1.1

$ kubectl describe node|grep beta.kubernetes.io/arch
Labels:             beta.kubernetes.io/arch=amd64
Labels:             beta.kubernetes.io/arch=amd64
Labels:             beta.kubernetes.io/arch=amd64
Labels:             beta.kubernetes.io/arch=arm64

3.小结

通过以上步骤,我们就成功实现了在amd64集群中添加arm64节点;充分利用了kubeasz 项目部署集群的灵活性和可配置性;

部署过程中ansible执行的过程性输出内容,以近乎白盒的方式展示每一个细节;假如出错有详细的说明,帮助定位,并且随时可以修改执行脚本,安装的幂等性保证随时可以重新安装以修复错误

相关推荐
凤山老林12 小时前
27-Java final 关键字
java·开发语言
少许极端12 小时前
算法奇妙屋(四十九)-贡献法
java·算法·leetcode·贡献法
卷毛的技术笔记12 小时前
从零到一:深入浅出分布式锁原理与Spring Boot实战(Redis + ZooKeeper)
java·spring boot·redis·分布式·后端·面试·java-zookeeper
aXin_ya12 小时前
微服务 第五天 (elasticsearch基础)
elasticsearch·微服务·架构
天空属于哈夫克312 小时前
行为审计与全链路追踪:私域自动化执行的安全性设计
java·运维·微服务
薛定猫AI12 小时前
【深度解析】Qwen 3.6 Max Preview 技术全景:MoE 架构、长上下文取舍与 AI Coding Agent 落地实践
人工智能·架构
skilllite作者12 小时前
SkillLite 技术演进笔记:Workspace、沙箱与进化
java·开发语言·前端·笔记·安全·agentskills
爱编程的陶老师12 小时前
云原生入门系列|第2集:搭建你的第一个K8s实验环境 —— minikube 零基础教程
云原生·容器·kubernetes
乐观勇敢坚强的老彭12 小时前
C++信奥洛谷循环章节练习题
java·c++·算法
菜菜小狗的学习笔记12 小时前
八股(八)Maven、Git、Docker
java·maven