今天介绍使用 sealos 一键部署 Kubernetes 集群, sealos 是只能用丝滑一词形容的kubernetes高可用安装(kubernetes install)工具,一条命令,离线安装,包含所有依赖,内核负载不依赖haproxy keepalived,纯golang开发,99年证书,支持v1.20.0 v1.19.5 v1.18.13 v1.17.15!
sealos 支持的环境
Linux 发行版, CPU架构
- Debian 9+, x86_64/ arm64
- Ubuntu 16.04, 18.04, 20.04, x86_64/ arm64
- Centos/RHEL 7.6+, x86_64/ arm64
- 其他支持 systemd 的系统环境. x86_64/ arm64
- Kylin arm64
kubernetes 版本
- 1.16+
- 1.17+
- 1.18+
- 1.19+
- 1.20+
- 1.21+
- 1.22+
要求和建议
最低资源要求
- 2 vCpu
- 4G Ram
- 40G+ 存储
操作系统要求
- ssh 可以访问各安装节点
- 各节点主机名不相同,并满足kubernetes的主机名要求。
- 各节点时间同步
- 网卡名称如果是不常见的,建议修改成规范的网卡名称, 如(eth.|en.|em.*)
- kubernetes1.20+ 使用containerd作为cri. 不需要用户安装docker/containerd. sealos会安装1.3.9版本containerd。
- kubernetes1.19及以下 使用docker作为cri。 也不需要用户安装docker。 sealos会安装1.19.03版本docker
网络和 DNS 要求:
- 确保 /etc/resolv.conf 中的 DNS 地址可用。否则,可能会导致群集中coredns异常。
- 如果使用阿里云/华为云主机部署。 默认的pod网段会和阿里云的dns网段冲突, 建议自定义修改pod网段, 在init的时候指定
--podcidr
来修改。 - sealos 默认会关闭防火墙, 如果需要打开防火墙, 建议手动放行相关的端口。
内核要求:
- cni组件选择cilium时要求内核版本不低于5.4
安装部署
- 下载并安装sealos, sealos是个golang的二进制工具,直接下载拷贝到bin目录即可, release页面也可下载
wget -c https://sealyun.oss-cn-beijing.aliyuncs.com/latest/sealos && \
chmod +x sealos && mv sealos /usr/bin
- 提前下载好对应 k8s 的离线资源包 kube1.22.1.tar.gz 。
- 安装一个单 master 三个 node 的 kubernetes 集群
sealos init --passwd '123456' \
--master 192.168.1.45 \
--node 192.168.1.46 --node 192.168.1.47 --node 192.168.1.48 \
--pkg-url ~/kube1.22.1.tar.gz \
--version v1.22.1
过了一会儿,可以看到如下场景,
执行 kubectl cluster-info 和 kubectl get nodes ,可以看到如下场景,表示 K8S 顺利部署安装。
清理集群 使用 sealos clean –all 可以清理集群