环境配置
本地虚拟机版本:VMware Workstation 16
k8s-master节点:2核4G、CentOS 7系统、40G磁盘 ip地址:192.168.1.134
k8s-node-01节点:1核2G、CentOS 7系统、40G磁盘 ip地址:192.168.1.135
k8s-node-02节点:1核2G、CentOS 7系统、40G磁盘 ip地址:192.168.1.136
阿里云CentOS 7镜像下载地址:http://mirrors.aliyun.com/centos/7.9.2009/isos/x86_64/
一、安装前置条件
- 一台或多台机器 (本次实验使用三台主机,一个master节点,两个node节点)
- 硬件配置:2GB或以上内存,master节点2核或以上,node节点1核或以上,硬盘40GB或以上
- 集群中所有机器之间内网互通,需要可以访问公网(需要通过公网拉取相关镜像,也可以部署本地私有镜像库通过内网拉取)
- 禁止swap分区
二、安装kubernetes之前系统的相关配置
1.关闭firewalld防火墙并设置禁止开机自启动
systemctl stop firewalld
systemctl disable firewalld
2.关闭selinux
sed -i ‘s/enforcing/disabled/’ /etc/selinux/config
3.关闭swap
swapoff -a
4.分别在三台主机上设置主机名
hostnamectl set-hostname k8s-master
hostnamectl set-hostname k8s-node-01
hostnamectl set-hostname k8s-node-02
5.设置/etc/hosts
192.168.1.134 k8s-master
192.168.1.135 k8s-node-01
192.168.1.136 k8s-node-02
6.将桥接的IPv4流量传递到iptables链
cat > /etc/sysctl.d/k8s.conf << EOF
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
EOF
sysctl --system ##执行命令使其生效
7.配置阿里云docker和kubernetes源
7.1.配置阿里云docker源
yum install -y yum-utils device-mapper-persistent-data lvm2
yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
sed -i 's+download.docker.com+mirrors.aliyun.com/docker-ce+' /etc/yum.repos.d/docker-ce.repo
yum makecache
7.2.配置阿里云kubernetes源
cat <<EOF > /etc/yum.repos.d/kubernetes.repo
[kubernetes]
name=Kubernetes
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
三、安装docker和kubernetes
1.安装docker、启动并设置开机自启动
yum install docker-ce-19.03.9-3.el7 docker-ce-cli-19.03.9-3.el7 containerd.io -y ##可以执行yum list docker-ce --showduplicates |sort -r 命令查看可安装的docker版本,此处指定版本安装
systemctl start docker
systemctl enable docker
2.安装kubeadm、kubelet、kubectl并设置开机自启动(不需要执行启动kubelet,后面会自动启动,在node节点上不需要安装kubectl)
yum install -y kubeadm-1.19.0 kubelet-1.19.0 kubectl-1.19.0 ##安装kubeadm、kubelet、kubectl,此处指定版本安装
systemctl enable kubelet
注:以上操作在三台机器上都需要执行
3.在master节点上部署kubernetes
kubeadm init --kubernetes-version=1.19.0 --apiserver-advertise-address=192.168.1.134 --image-repository registry.aliyuncs.com/google_containers --service-cidr=10.96.0.0/12 --pod-network-cidr=10.244.0.0/16 ##--apiserver-advertise-address参数填写master主机的地址
注:此操作只需要在master节点上执行,看到上述successfully,说明安装已经成功,需要将红框中的kubeadm信息复制一下,后面会使用到
4.创建文件夹将admin.conf文件复制到对应的位置
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
scp -p /etc/kubernetes/admin.conf root@k8s-node-01:/etc/kubernetes/admin.conf
scp -p /etc/kubernetes/admin.conf root@k8s-node-02:/etc/kubernetes/admin.conf
5.将两台node节点加入到集群中,分别在node01和node02上执行刚刚 kubeadm init成功后下面打印的命令:
kubeadm join 192.168.1.134:6443 --token e980m6.82nydanu5z75luob \
--discovery-token-ca-cert-hash sha256:87693d212fa85acbc210d3d0d466142cb94fba18f00f1ee1d2fc2cdda45b7bb5
在master节点执行kubectl get nodes命令查看一下节点信息
6.安装部署CNI网络插件
6.1在master节点上执行命令
kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
6.2 执行下列命令验证一下
kubectl get pods -n kube-system
到此通过kubeadm安装kubernetes基本就结束了。