使用VirtualBox【四步】搭建Kubernetes集群(2023-02-13)

文章内容:

  • 使用VirtualBox、Containerd、Kubeadm等在本地搭建一个用于测试的3节点Kubernetes集群。
  • 搭建过程中踩过的坑以及解决方案说明。
  • 搭建环境:MacOS Monterey(宿主机) / CentOS 7(虚拟机) / Kubernetes 1.26.1 / VirtualBox 7.0.2

1、创建虚拟机

虚拟机说明
为了搭建Kubernetes集群,需要准备3台虚拟机,一个Master节点两个Node节点。以上是我本地已经创建好的三台虚拟机。这里需要说明一下,不要一开始就直接创建3台机器,不然像各种防火墙配置、Containerd安装都需要操作三遍。可以先创建一台,完成第二节【初始化虚拟机环境】操作,在执行kubeadm init之前复制出两个Node节点,这样能减少不少工作量。

如何使用VirtualBox创建虚拟机的教程网上有不少,这里就不重复描述了,只重点讲一些需要注意事项:

  • 我这搭建环境,虚拟机使用的操作系统是CentOS7,使用的iso文件是CentOS-7-x86_64-Everything-2009.iso,推荐下载的时候直接选择Everything版,可以减少大量虚拟机安装时间。
  • Master节点的虚拟机配置,推荐4C8G。一开始我使用的是2C2G,安装好集群之后kube-scheduler-masterkube-controller-manager-master疯狂的crash,给Master升配之后基本就稳定了。
  • 建议给每台虚拟机都加一块Host-only Network网卡,这样可以从宿主机terminal直接ssh到虚拟机操作,避免鼠标键盘经常被虚拟机锁定、各种复制粘贴问题;后续Kubernetes集群也可以直接从宿主机访问。

2、初始化虚拟机环境

在上面创建好的Master虚拟机中执行以下命令:

# 关闭防火墙
> systemctl stop firewalld
> systemctl disable firewalld

# 关闭selinux
> sed -i 's/enforcing/disabled/' /etc/selinux/config
> setenforce 0 

# 关闭swap
> swapoff -a
> sed -ri 's/.*swap.*/#&/' /etc/fstab

# 将桥接的IPv4流量传递到iptables的链
> cat > /etc/sysctl.d/k8s.conf << EOF
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
EOF

# 配置时间同步
> yum install ntpdate -y
> ntpdate time.windows.com

# 安装vim
> yum install vim -y

# 安装wget,后面会用到
> yum install wget -y

# 生效
> sysctl --system 

# 最终安装的Kubernetes版本是1.26.1,需要安装Containerd
> yum install -y yum-utils device-mapper-persistent-data lvm2
> yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
> yum install containerd -y
> containerd config default > /etc/containerd/config.toml
> systemctl restart containerd
> systemctl status containerd

# ********这里注释的内容需要vim改一下***************
# vim修改containerd配置
# vim /etc/containerd/config.toml
# 替换sandbox_image = "registry.aliyuncs.com/google_containers/pause:3.6"
# 这里可以顺手把拉镜像的mirrors也设置了

# 替换完成后重启containerd
> systemctl daemon-reload
> systemctl restart containerd

# 写入crictl配置文件
> cat > /etc/crictl.yaml << EOF
runtime-endpoint: unix:///run/containerd/containerd.sock
image-endpoint: unix:///run/containerd/containerd.sock
timeout: 10
debug: false
EOF

# 添加kubernetes软件源
> cat > /etc/yum.repos.d/kubernetes.repo << EOF
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64
enabled=1
gpgcheck=0
repo_gpgcheck=0
gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
EOF

# 安装kubelet、kubeadm、kubectl
> yum install -y kubelet-1.26.1 kubeadm-1.26.1 kubectl-1.26.1

# 设置kubelet开机启动
> systemctl enable kubelet

如果能顺利的走到这里,就可以开始复制虚拟机了,后面的操作需要区分Master和Node角色。如果不了解VirtualBox如何复制虚拟机可以搜一搜相关的文档,这里就不多说了。

复制完成后,在Master虚拟机上继续操作:

# 设置主机名
><
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

影踪3726

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值