一、前言
1、我前面文章有写过使用 kubeadm
安装的方式,大家可以去参考 (二)k8s集群安装,有一系列的k8s文章说明
2、安装k8s的方式有很多
- kubeadm
- sealos
- kubespray
- 等等
3、关于sealos来安装 k8s ,也是非常建议大家去官方文档看看,安装sealos和k8s,说的很非常清楚,一看就知道
4、这里顺便说一下 Sealos
和 Sealer
。它们都是与 Kubernetes 相关的工具,但用途和功能不同。
-
Sealos:
Sealos 是一个用于快速部署 Kubernetes 集群的工具。它基于 Ansible 和 KubeAdm,旨在简化 Kubernetes 集群的安装过程。Sealos 提供了一种快速、便捷的方式来部署单节点或多节点的 Kubernetes 集群。它可以自动处理节点初始化、Master 和 Worker 节点的部署,以及集群的配置和初始化。Sealos 主要关注于 Kubernetes 集群的部署和初始化过程,使得用户能够更容易地搭建一个运行的 Kubernetes 环境。 -
Sealer:
Sealer 是一个用于加密和保护 Kubernetes 配置文件的工具。它可以将 Kubernetes 的配置文件(如 kubeconfig 文件)进行加密,以确保敏感信息在存储和传输过程中得到保护。Sealer 可以使用不同的加密算法对配置文件进行加密,然后在使用时再进行解密。这有助于提高 Kubernetes 集群的安全性,尤其是在管理多个集群时,可以更好地保护配置信息。
总结:
- Sealos 主要用于 Kubernetes 集群的快速部署和初始化。
- Sealer 主要用于加密和保护 Kubernetes 配置文件,增强集群的安全性。
二、前置准备和说明
2.1、集群类型
kubernetes集群大体上分为两类:一主多从和多主多从。
- 一主多从:一台Master节点和多台Node节点,但是有单机故障风险,适合用于测试环境
- 多主多从:多台Master节点和多台Node节点,安全性高,适合用于生产环境
说明:为了测试简单,本次搭建的是 一主两从 类型的集群
2.2、主机规划
1、各个机器配置
作用 | ip | 操作系统 | 配置 |
---|---|---|---|
k8s-master01 | 192.168.173.135 | Centos7.9 基础设施服务器 | 4颗CPU 4G内存 100G硬盘 |
k8s-node01 | 192.168.173.136 | Centos7.9 基础设施服务器 | 2颗CPU 4G内存 100G硬盘 |
k8s-node02 | 192.168.173.137 | Centos7.9 基础设施服务器 | 2颗CPU 4G内存 000G硬盘 |
2、相关网络配置
IPADDR=xxxxxx
NETMASK=255.255.255.0
GATEWAY=192.168.173.2
3、DNS
nameserver 8.8.8.8
nameserver 114.114.114.114
2.3、安装说明
2.3.1、环境初始化(所有节点都需要做的)
1、检查操作系统的版本,因为此方式下安装kubernetes集群要求Centos版本要在7.5或之上(否则存在node节点无法加入master的情况)
cat /etc/redhat-release
2、主机名解析,为了方便后面集群节点间的直接调用,在这配置一下主机名解析,企业中推荐使用内部DNS服务器
# 主机名成解析 编辑三台服务器的/etc/hosts文件,添加下面内容
192.168.173.135 k8s-master01
192.168.173.136 k8s-node01
192.168.173.137 k8s-node02
3、设置每个节点的主机名称,这是为了后续使用k8s的时候,生成的节点是以我们的主机名称来命名的,不然k8s搭建之后生成的节点就是 master01,node01之类的等等
hostnamectl set-hostname k8s-master01
hostnamectl set-hostname k8s-node01
hostnamectl set-hostname k8s-node02
3、修改完成后测试是否正常,没一台都测试一下,避免后面安装的时候再发现问题,可就难受了。
-
k8s-master01节点
-
k8s-node01节点
- k8s-node02节点
4、时间同步,kubernetes要求集群中的节点时间必须精确一致,这里使用 NTP同步网络时间,当然如果你是内网,不能链接外网,那你最好搭建一个企业内部的时间同步服务器,其他机器都从这台时间服务器同步,保证完全一致。
# 主机名成解析 编辑三台服务器的/etc/hosts文件,添加下面内容
yum install ntp -y //安装ntp服务systemctl enable ntpd //开机启动服务systemctl start ntpd //启动服务timedatectl set-timezone Asia/Shanghai //更改时区timedatectl set-ntp yes //启用ntp同步ntpq -p //同步时间
2.3.2、安装sealos
1、安装的方式很多,大家也可以参考官方,有四种安装方式
- 二进制自动下载
- 二进制手动下载
- 包管理工具安装
- 源码安装
官方地址-安装sealos
2.3.2.1、二进制手动下载安装
1、截至我写这篇文章为止,目前sealos
的版本如下,我们选择安装 v4.3.0
即可
注意:在选择版本时,建议使用稳定版本例如v4.3.0。像v4.3.0-rc1、v4.3.0-alpha1这样的版本是预发布版,请谨慎使用
2、在k8s-master01节点 下载
wget https://github.com/labring/sealos/releases/download/v4.3.0/sealos_v4.3.0_linux_amd64.tar.gz
3、解压后重命名 sealos
,解压完成后,会发现只有这一个可执行的文件
4、赋予可执行权限,并移动到当前用户的bin 目录下面,这样方便我们可以在任何地方都去使用它
chmod +x sealos && mv sealos /usr/bin
2.3.3、安装k8s
先决条件,sealos 是一个简单的 go 二进制文件,可以安装在大多数 Linux 操作系统中。以下是一些基本的安装要求:
- 每个集群节点应该有不同的主机名。 主机名不要带下划线。
- 所有节点的时间同步。
- 在 Kubernetes 集群的第一个节点上运行sealos run命令,目前集群外的节点不支持集群安装。
- 建议使用干净的操作系统来创建集群。不要自己装 Docker。
- 支持大多数 Linux 发行版,例如:Ubuntu CentOS Rocky linux。
- 支持 DockerHub 中支持的 Kubernetes 版本。
- 支持使用 containerd 作为容器运行时。
- 在公有云上请使用私有 IP。
1、安装命令如下
这个底层是使用
containerd
,如果你希望底层还是使用docker,可以看我后面的第6步,将如下命令中的labring/kubernetes:v1.25.0
镜像换成labring/kubernetes-docker:v1.25.0
即可
$ sealos run labring/kubernetes:v1.25.0 labring/helm:v3.8.2 labring/calico:v3.24.1 \--masters 192.168.173.135 \--nodes 192.168.173.136,192.168.173.137 -p 123456
如果你需要安装HA的模式,即高可用多个master节点,也非常简单,命令如下,即在参数masters后面以逗号分割多个master节点ip即可
$ sealos run labring/kubernetes:v1.25.0 labring/helm:v3.8.2 labring/calico:v3.24.1 \--masters 192.168.64.2,192.168.64.22,192.168.64.20 \--nodes 192.168.64.21,192.168.64.19 -p [your-ssh-passwd]
2、执行命令之后,你会发现大部分时间都在下载镜像,所以这个速度和你的网速还是有很大关系的
这里无需科学上网,因为这里的镜像 sealos 都从dockerHub 上面下载的,sealos都已经帮我们处理好了。
3、安装完成之后的界面
4、查看集群情况
kubectl get node
5、注意,因为k8s从1.20版本开始就不再使用docker
,而是使用更加底层的 containerd
,所以我们安装完成后,是没有docker的命令的
其实 docker 底层也是
containerd
,k8s舍弃docker是,因为功能有些相同,关于这个方面的内容,大家可以参考这一篇文章 containerd的安装与使用 里面详细说明了k8s,docker,containerd的关系,简单明了
6、如果你希望安装k8s底层是docker的版本,可以将第一步的安装命令改为如下即可
$ sealos run labring/kubernetes-docker:v1.25.0 labring/helm:v3.8.2 labring/calico:v3.24.1 \--masters 192.168.173.135 \--nodes 192.168.173.136,192.168.173.137 -p 123456
两种的区别是
- labring/kubernetes-docker:v1.25.0 (使用
docker
) - labring/kubernetes:v1.25.0 (使用默认的
containerd
)
2.4、sealos相关命令
2.4.1、增加节点
1、增加 node 节点:
sealos add --nodes 192.168.64.21,192.168.64.19
2、增加 master 节点:
sealos add --masters 192.168.64.21,192.168.64.19
2.4.2、删除节点
1、删除 node 节点:
sealos delete --nodes 192.168.64.21,192.168.64.19
2、删除 master 节点:
sealos delete --masters 192.168.64.21,192.168.64.19
2.4.3、清理集群
$ sealos reset
三、页面管理工具(Kuboard)安装部署
1、这一章大家可以随意,不安装的话就使用命令行,或者用k8s原生的页面控制,不过原生的页面控制台不太好用,我个人还是建议安装一下这个。
2、关于这个我也有在k8s系列文章中提起 (十一)k8s其它帮助&&单节点部署 这里就不再重复啰嗦了 , 而且官方文档还是中文的,也很详细。