1.开始操作之前要先关闭防火墙,SELinux,swap分区
关闭防火墙
sudo systemctl stop firewalld关闭SELinux
sudo setenforce 0 # 临时关闭
sudo sed -i 's/^SELINUX=enforcing$/SELINUX=permissive/' /etc/selinux/config # 永久关闭关闭swap分区
swapoff -a # 临时关闭
sed -i.bak '/swap/s/^/#/' /etc/fstab # 永久关闭
2.安装docker,这里不再做过多描述,步骤请参考:centos/linux在线安装docker
3.更改daemon.json文件,指定 Docker 守护进程使用的 cgroup 驱动程序
vim /etc/docker/daemon.json (如果没有就创建一个)
{"exec-opts": ["native.cgroupdriver=systemd"]
}
4.重启docker
systemctl restart docker
5.修改hosts文件 k8smaster为主机地址,下面为node节点地址,有几个加几个
cat >> /etc/hosts << EOF
192.168.47.99 k8smaster
192.168.47.136 node2
EOF
6.修改内核参数,确保容器内外的网络安全性和通信能力
cat >> /etc/sysctl.d/k8s.conf << EOF
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
EOF
7.设置kubernetes源
cat >> /etc/yum.repos.d/kubernetes.repo << EOF
[node2]
name=node2
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64/
enabled=1
gpgcheck=1
repo_gpgcheck=1
gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
EOF
第7步注释:
[node名称]
: 这是yum存储库的一个标识符,用于标识存储库的名称,node名称即可name=node2
: 这是存储库的名称,可读的名称,node名称即可baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64/
: 这是存储库的基本 url,指定了存储库中软件包的位置。在这里,指向了阿里云的 Kubernetes yum 存储库enabled=1
: 这是一个布尔值,用于指示存储库是否启用。1为启用,即yum将从该存储库中获取软件包gpgcheck=1
: 这也是一个布尔值,用于指示是否应该检查软件包的gpg签名以验证其完整性。值为1表示启用了gpg检查repo_gpgcheck=1
: 类似于gpgcheck
,用于指示是否应该检查存储库的gpg签名。1表示启用了对存储库gpg签名的检查https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
: 这里用于验证存储库和软件包签名的gpg密钥的url。这些密钥将用于验证从存储库中下载的软件包的完整性和真实性
######8-9也可以不用操作,为了严谨还是清理更新一下缓存
8.清理yum缓存
yum clean all
9.更新yum缓存
yum -y makecache
10.安装kubelet、kubeadm、kubectl
选择适合自己的版本安装,地址:Kubernetes版本
注意:docker版本要在k8s版本兼容范围之内,不然会有警告,不过问题也不是很大
sudo yum install -y kubelet-1.20.9 kubeadm-1.20.9 kubectl-1.20.9 --disableexcludes=kubernetes
11.启动kubelet并将kubelet设置开机自启
sudo systemctl start kubelet && systemctl enable kubelet
12.下载镜像,下载每个节点所需要的镜像
sudo cat >> ./images.sh << EOF
#!/bin/bash
images=(
kube-apiserver:v1.20.9
kube-proxy:v1.20.9
kube-controller-manager:v1.20.9
kube-scheduler:v1.20.9
coredns:1.7.0
etcd:3.4.13-0
pause:3.2
)
for imageName in ${images[@]} ; do
docker pull registry.cn-hangzhou.aliyuncs.com/lfy_k8s_images/$imageName
done
EOF
13.运行镜像脚本文件
chmod +x ./images.sh && ./images.sh
14.加入集群
复制master节点中kubeadm init最后的那两行kubaadm join XXXXXXXXX
在node节点中执行kubaadm join XXXXXXXXX
如果找不到join的命令,就重新生成一个(在master节点执行)
kubeadm token create --print-join-command
15.成功加入后的截图
警告:
安装kubelet、kubeadm、kubectl后kubelet会一直处于重启状态,不要在意status状态码是什么,在init之前或者加入集群之前kubelet都不会启动,启动会占用10250端口,一旦端口被占用就无法加入集群,具体请参考:K8S,node节点join失败,kubelet启动失败