基于Kubeasz部署Kubernetes高可用集群

文章描述了如何准备多台服务器来构建一个Kubernetes集群,包括关闭防火墙和SELinux,安装必要工具,使用Ansible和sshpass进行自动化部署,以及在遇到问题(如Calico节点连接不上apiserver)时如何解决,特别是强调了iptables工具在解决网络问题中的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

准备环境

1、准备如上机器,关闭firewalld、selinux,需要安装iptables、net-tools、vim等工具包

2、在deploy机器上安装ansible、sshpass

3、在deploy机器上生成ssh公钥,并将公钥同步到各节点上

4、使用ezctl脚本创建一个集群的工作目录

5、按步骤初始化集群


准备环境

类型IP地址主机名
k8s-etcd110.49.33.65

k8s-etcd1.likai.com

k8s-etcd210.49.33.66k8s-etcd2.likai.com
k8s-etcd310.49.33.67k8s-etcd3.likai.com
k8s-master110.49.33.83k8s-master1.likai.com
k8s-master210.49.33.84k8s-master2.likai.com
k8s-master310.49.33.85k8s-master3.likai.com
k8s-node110.49.33.92k8s-node1.likai.com
k8s-node210.49.33.93k8s-node2.likai.com
k8s-node310.49.33.94k8s-node3.likai.com
deploy10.49.33.147

1、准备如上机器,关闭firewalld、selinux,需要安装iptables、net-tools、vim等工具包

2、在deploy机器上安装ansible、sshpass

3、在deploy机器上生成ssh公钥,并将公钥同步到各节点上

d764fe4289b845a8a821d747aab46cb3.png

4、使用ezctl脚本创建一个集群的工作目录

08083cf5af1744209b9595d37abdbacf.png

执行后会在deploy机器上创建一个目录/etc/kubeasz/clusters/k8s-cluster1,该目录下有hosts、config.yml两个文件;

hosts是配置这个集群包含的机器的文件,包含机器组、网络组件选择配置等

ea833b1894b1448ba889fce2d5227985.png

config.yml文件是一些具体的配置项:

7a75136a9d6446c7b12d5bb43d9f7b2a.png

 hosts、config.yml两个文件修改成预期的项目后,就可以开始初始化集群

5、按步骤初始化集群

2c7dfea3b2774096896c07369833557e.png

01步骤是准备阶段,包含卸载、安装、关闭selinux、swap、修改内核参数等 

0303cfbb7eb240b6ac27f680a8561fac.png

 02步骤部署etcd

155331fa6077475eb0c062a69d7f3c65.png

03初始化container-runtime运行时

2b2b1ab2eff143fd879bde7e76553e58.png

04初始化master节点

ed64aac47bef43edb4d9926f9276c745.png 05初始化node节点

73e88c1693464b0299a1a125d3dc28f6.png

 06部署网络插件calico

de05c8c66b7e4d6c82f01e97593950ee.png

 这个步骤我卡了一个星期,work节点上的calico-node一直连不上集群的apiserver地址,最后翻容器日志发现需要用到iptabels工具,但节点上没有这个工具,通用yum安装iptaibnes后,解决了这个问题 

572539be38154a1b89d26377e55e231f.png

 cd0789d491964bedad66c5edc17e151d.png

ac3ddddaa8ed47b6b77ff8a2a11f30ca.png


扫一扫关注作者公众号

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值