目录
[所有节点安装docker :](#所有节点安装docker :)
所有节点安装kubeadm,kubelet和kubectl:
[修改了 kubeadm-config.yaml,将其传输给其他master节点,先完成所有master节点的镜像拉取:](#修改了 kubeadm-config.yaml,将其传输给其他master节点,先完成所有master节点的镜像拉取:)
修改controller-manager和scheduler配置文件:
使用Kubeadm安装k8s集群:
环境准备:2主2从
master01,02:192.168.233.10,192.168.233.20
node01,02:192.168.233.30,192.168.233.40
负载均衡器:192.168.233.50,192.168.233.60
注意事项:
master节点cpu核心数要求大于2
最新的版本不一定好,但相对于旧版本,核心功能稳定,但新增功能、接口相对不稳
学会一个版本的 高可用部署,其他版本操作都差不多
宿主机尽量升级到CentOS 7.9
内核kernel升级到 4.19+ 这种稳定的内核
部署k8s版本时,尽量找 1.xx.5 这种大于5的小版本(这种一般是比较稳定的版本)
初始化操作:
每台主从节点:
systemctl stop firewalld
systemctl disable firewalld
data:image/s3,"s3://crabby-images/dbdec/dbdec895327440fa0ea88b7c1cf0b9dd794be139" alt=""
setenforce 0
sed -i 's/enforcing/disabled/' /etc/selinux/config
data:image/s3,"s3://crabby-images/4a57c/4a57c25dcfac7f2d72685007ea5e95268e66eb4f" alt=""
iptables -F && iptables -t nat -F && iptables -t mangle -F && iptables -X
data:image/s3,"s3://crabby-images/50e26/50e2614b82032ca399c9c04df845520971d5d863" alt=""
swapoff -a
sed -ri 's/.*swap.*/#&/' /etc/fstab
data:image/s3,"s3://crabby-images/a55e2/a55e206633b510b031450bd40f6a3fdae1bc0d7d" alt=""
for i in (ls /usr/lib/modules/(uname -r)/kernel/net/netfilter/ipvs|grep -o "^[^.]*");do echo $i; /sbin/modinfo -F filename $i >/dev/null 2>&1 && /sbin/modprobe $i;done
data:image/s3,"s3://crabby-images/2b0a8/2b0a81d623f0056e4042e8bc08f251523222596d" alt=""
hostnamectl set-hostname master01
hostnamectl set-hostname master02
hostnamectl set-hostname node01
hostnamectl set-hostname node02
data:image/s3,"s3://crabby-images/f2c20/f2c2087f53b025eebea67a8694b76aaad89e750c" alt=""
data:image/s3,"s3://crabby-images/dae1c/dae1c71a4bc3e65ac6286f58b1843502e2b3017a" alt=""
data:image/s3,"s3://crabby-images/b2055/b2055382e8f6b1e47216c3fc40a050df76fa99ca" alt=""
data:image/s3,"s3://crabby-images/8e803/8e803c6f53d7529e88aad935a2c5d96723d5bcfe" alt=""
vim /etc/hosts
192.168.233.10 master01
192.168.233.20 master02
192.168.233.30 node01
192.168.233.40 node02
data:image/s3,"s3://crabby-images/76b02/76b020822e83bf62cc29bf4587f437acde9f4e89" alt=""
data:image/s3,"s3://crabby-images/466d2/466d28449d09ca86ea6411d8a95c0d69da61f06f" alt=""
cat > /etc/sysctl.d/kubernetes.conf << EOF
#开启网桥模式,可将网桥的流量传递给iptables链
net.bridge.bridge-nf-call-ip6tables=1
net.bridge.bridge-nf-call-iptables=1
#关闭ipv6协议
net.ipv6.conf.all.disable_ipv6=1
net.ipv4.ip_forward=1
EOF
sysctl --system
data:image/s3,"s3://crabby-images/d0e73/d0e735a287facd76dbb69bb3ce3bb19cd51ee3cc" alt=""
yum -y install ntpdate
ntpdate ntp.aliyun.com
data:image/s3,"s3://crabby-images/a41c5/a41c515e22ca29226aeade7f402df85ec3fc24bb" alt=""
data:image/s3,"s3://crabby-images/5ff67/5ff67cd244400bd316d1a04feaca2fc93cce5eec" alt=""
crontab -e
*/30 * * * * /usr/sbin/ntpdate ntp.aliyun.com &> /dev/null
data:image/s3,"s3://crabby-images/c3ab9/c3ab94be807c972acefe551e7f85b96bdf84d584" alt=""
data:image/s3,"s3://crabby-images/c4b42/c4b424aba28cbc2eb5891c3a580e05a258c5be47" alt=""
data:image/s3,"s3://crabby-images/1b090/1b09049582b1f2e8b766ab684d5d800a7608d461" alt=""
升级内核:
data:image/s3,"s3://crabby-images/882f0/882f01b6d17e93fc13786b60e5a3782ee1e5bc2b" alt=""
data:image/s3,"s3://crabby-images/f5f89/f5f89fe2b27b49a58ff90e5f67b943d656c0f048" alt=""
data:image/s3,"s3://crabby-images/6d8c6/6d8c650871c5edc9abd4049b1587993635f08e3f" alt=""
[elrepo]
name=elrepo
baseurl=https://mirrors.aliyun.com/elrepo/archive/kernel/el7/x86_64
gpgcheck=0
enabled=1
data:image/s3,"s3://crabby-images/74763/74763640a281cf8840c8e05a4deadc58b59c2644" alt=""
升级所有节点内核:
yum install -y kernel-lt-devel kernel-lt
data:image/s3,"s3://crabby-images/f1d60/f1d60a5efcbb38f95e3a26d4a520c1a517942094" alt=""
awk -F\' '$1=="menuentry " {print i++ " : " $2}' /etc/grub2.cfg
data:image/s3,"s3://crabby-images/7918c/7918c2153403b9e15dc71913ca37ae892b621f70" alt=""
设置默认启动内核
grub2-set-default 0
data:image/s3,"s3://crabby-images/a7717/a771785a967c7151a86c1d8ed265b483dfb39cf0" alt=""
修改内核参数:
vim /etc/security/limits.conf
data:image/s3,"s3://crabby-images/08674/08674bb950d674804c3e27c3021813cf3ddd002c" alt=""
* soft nofile 65536
* hard nofile 65536
* soft nproc 65536
* hard nproc 65536
* soft memlock unlimited
* hard memlock unlimited
data:image/s3,"s3://crabby-images/566bf/566bf09e67aa74119bbcfd26fdcbaab8bc6cdb57" alt=""
重启:
reboot
data:image/s3,"s3://crabby-images/3cacb/3cacbcd1c9882fa940b289803f1e2887a94b17bc" alt=""
data:image/s3,"s3://crabby-images/468c3/468c3d6d0d3a5e5c942d17a2f31ab0eb279fe03f" alt=""
ulimit -a
data:image/s3,"s3://crabby-images/8a0f5/8a0f57b48635267c6aa2162341e0112a0f4ce8d1" alt=""
for i in (ls /usr/lib/modules/(uname -r)/kernel/net/netfilter/ipvs|grep -o "^[^.]*");do echo $i; /sbin/modinfo -F filename $i >/dev/null 2>&1 && /sbin/modprobe $i;done
data:image/s3,"s3://crabby-images/25f1f/25f1f99450f4856ba8aa2c09a340b8e19ff5d93b" alt=""
所有节点安装docker :
yum install -y yum-utils device-mapper-persistent-data lvm2
data:image/s3,"s3://crabby-images/f58ff/f58ffdba193bd265aa474a5bdf9d8cfead6868a3" alt=""
yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
data:image/s3,"s3://crabby-images/74ee6/74ee6e949ee81ae1717b79ade9484b14b9aa8c03" alt=""
yum install -y docker-ce docker-ce-cli containerd.io
data:image/s3,"s3://crabby-images/21ee8/21ee891b1605e604b49213698a839a3805699ba1" alt=""
cat > /etc/docker/daemon.json <<EOF
{
"registry-mirrors": ["https://6ijb8ubo.mirror.aliyuncs.com"],
"exec-opts": ["native.cgroupdriver=systemd"],
"log-driver": "json-file",
"log-opts": {
"max-size": "500m", "max-file": "3"
}
}
EOF
data:image/s3,"s3://crabby-images/41c52/41c52ef0d329245e5d376e60d0492f5617220731" alt=""
data:image/s3,"s3://crabby-images/99e71/99e711862c9ab75ac16357d01bcec8113551333a" alt=""
systemctl daemon-reload
systemctl restart docker.service
systemctl enable docker.service
data:image/s3,"s3://crabby-images/b11a0/b11a01918e9ec18ba189b99966938cbfce0942cd" alt=""
data:image/s3,"s3://crabby-images/5912a/5912aea99f1945eb38283af5fa1caaf6740a6ea0" alt=""
docker info | grep "Cgroup Driver"
data:image/s3,"s3://crabby-images/776c0/776c03013ebab2adb5ef1c2d027f81c55b23ede8" alt=""
所有节点安装kubeadm,kubelet和kubectl:
定义kubernetes源:
bash
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
data:image/s3,"s3://crabby-images/57126/57126928dbb6d827643cf05763823b0df37c53e1" alt=""
yum install -y kubelet-1.20.15 kubeadm-1.20.15 kubectl-1.20.15
data:image/s3,"s3://crabby-images/831d7/831d76950b4d7ae46d7121fabb3a4daeda4ac29b" alt=""
配置Kubelet使用阿里云的pause镜像:
cat > /etc/sysconfig/kubelet <<EOF
KUBELET_EXTRA_ARGS="--cgroup-driver=systemd --pod-infra-container-image=registry.cn-hangzhou.aliyuncs.com/google_containers/pause-amd64:3.2"
EOF
data:image/s3,"s3://crabby-images/858c5/858c57ab8162a78e7831c2d41535e1ce2d3c961d" alt=""
开机自启kubelet:
systemctl enable --now kubelet
data:image/s3,"s3://crabby-images/ff45c/ff45c6dc84f84b61a2daabd7d649ddb7836bcc42" alt=""
在负载均衡器上部署nginx和keepalived(跟二进制安装的一样):
data:image/s3,"s3://crabby-images/670d4/670d4b01389d0de019f1ca2c5906ecc0d032760b" alt=""
在 master01 节点上设置集群初始化配置文件:
kubeadm config print init-defaults > /opt/kubeadm-config.yaml
data:image/s3,"s3://crabby-images/f2be0/f2be0d0b83c4407278cf0043d5db52e10d6c4dc9" alt=""
修改内容:
data:image/s3,"s3://crabby-images/11510/115107e87a06674565f178bcbd217c763f206256" alt=""
data:image/s3,"s3://crabby-images/c8e96/c8e96a1ce287f94d9983a40d6e82a510caba6f7f" alt=""
可选,有则添加,没有则用自带的local模块:
external:
endpoints:
caFile: /opt/etcd/ssl/ca.pem
certFile: /opt/etcd/ssl/server.pem
keyFile: /opt/etcd/ssl/server-key.pem
data:image/s3,"s3://crabby-images/b8c87/b8c87c564f03b6acd1f63ea58ba63b87b8b6c426" alt=""
podSubnet: "10.244.0.0/16"
apiVersion: kubeproxy.config.k8s.io/v1alpha1
kind: KubeProxyConfiguration
mode: ipvs
data:image/s3,"s3://crabby-images/58936/5893622a4c1f52eda41275b6420300820cf1fedd" alt=""
修改了 kubeadm-config.yaml,将其传输给其他master节点,先完成所有master节点的镜像拉取:
scp kubeadm-config.yaml master02:/opt/
data:image/s3,"s3://crabby-images/c07c8/c07c8a591519b6f0b775d1cf1d04cde88f295265" alt=""
kubeadm config images pull --config /opt/kubeadm-config.yaml
data:image/s3,"s3://crabby-images/ce786/ce786d84b4e5b0d21809b4d65349a925a8a5b411" alt=""
data:image/s3,"s3://crabby-images/e6703/e670307b1e2f3a7863acf0d4e915719170ccaeff" alt=""
master01 节点进行初始化:
kubeadm init --config kubeadm-config.yaml --upload-certs | tee kubeadm-init.log
data:image/s3,"s3://crabby-images/6a152/6a152bbd671513fd19fb5adf02f9e70c3e68c5f4" alt=""
配置 kubectl:
mkdir -p $HOME/.kube
cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
chown (id -u):(id -g) $HOME/.kube/config
data:image/s3,"s3://crabby-images/0c1ff/0c1ff7bd731c08df76f4f4132790ebd44b9654fb" alt=""
data:image/s3,"s3://crabby-images/edf52/edf52d65061b50b14a56ba73f8f4fc42dc4709bf" alt=""
data:image/s3,"s3://crabby-images/c3868/c3868900a87b6cd01340cd9895ff4fee0dc3512c" alt=""
修改controller-manager和scheduler配置文件:
vim /etc/kubernetes/manifests/kube-scheduler.yaml
vim /etc/kubernetes/manifests/kube-controller-manager.yaml
data:image/s3,"s3://crabby-images/3ce63/3ce6377db77ea6b1cd694be0a14083a41ea1d126" alt=""
data:image/s3,"s3://crabby-images/fd17d/fd17d81538b41e8011dbd701cb68bbe0224f1d56" alt=""
data:image/s3,"s3://crabby-images/7ee42/7ee429f65b1a70bf8dde7bfe670dd3779c67a496" alt=""
data:image/s3,"s3://crabby-images/e7ddc/e7ddc6118490a7bbf444b1573563273f7d4137ce" alt=""
systemctl restart kubelet
data:image/s3,"s3://crabby-images/f0f6f/f0f6f593363ed6d1dcd0a161a310ce0275198823" alt=""
初始化后会生成 etc/kubernetes/目录下文件:
data:image/s3,"s3://crabby-images/030cd/030cdb72f6c11936201df5a28bbd500de7885bd1" alt=""
其他节点也如此操作:
若初始化失败,进行的操作
kubeadm reset -f
ipvsadm --clear
rm -rf ~/.kube
再次进行初始化
master节点对接:
kubeadm join 192.168.233.100:6443 --token abcdef.0123456789abcdef \
--discovery-token-ca-cert-hash sha256:4b0444f7df160c2ae1515225cb4746c21ff7ce11099fc8540d63f333d93657d8 \
--control-plane --certificate-key 7be247a882d02fce65b7d6d224d29dbadc7c378299d8b50539f237657fa3cebf
data:image/s3,"s3://crabby-images/4c2d9/4c2d9b2b2b02111cefe308d1f1f5f381b0ed5169" alt=""
data:image/s3,"s3://crabby-images/81a2e/81a2ed988663da9ec30046c61b73deaef53619ad" alt=""
data:image/s3,"s3://crabby-images/30972/30972ea5911eb19463130bb40f7d3d7010868186" alt=""
node 节点加入集群:
kubeadm join 192.168.233.100:6443 --token abcdef.0123456789abcdef \
--discovery-token-ca-cert-hash sha256:4b0444f7df160c2ae1515225cb4746c21ff7ce11099fc8540d63f333d93657d8
data:image/s3,"s3://crabby-images/3923a/3923a6a060511f1666e776319921c9d62377d6d8" alt=""
data:image/s3,"s3://crabby-images/8e71e/8e71ec9fd9224bc155917b7ac5010acbb74212f0" alt=""
部署网络插件:
data:image/s3,"s3://crabby-images/dd9c1/dd9c1bcbc682fc2356affd91def2bd981330a395" alt=""
data:image/s3,"s3://crabby-images/20a3d/20a3dc3742e7f3f628a9885454329ba22d6b7ec3" alt=""
将文件传给master:
data:image/s3,"s3://crabby-images/90678/9067842b71d3e7550aa49157abab0693027456a8" alt=""
data:image/s3,"s3://crabby-images/a5309/a5309c1ee7aa95c695eaac17861308a618411650" alt=""
data:image/s3,"s3://crabby-images/18779/187790fcf79b8d85448e62c4ba2900bb927c30c1" alt=""
data:image/s3,"s3://crabby-images/7d0c5/7d0c5544c4b5a433ccde102289abc4a6fa8886c0" alt=""
部署dashboard:
在 master01 节点上操作上传 recommended.yaml 文件到 /opt/目录中:
data:image/s3,"s3://crabby-images/de6c4/de6c4bb2c79a0d696678b5e1339f5558686b716f" alt=""
创建service account并绑定默认cluster-admin管理员集群角色:
kubectl create serviceaccount dashboard-admin -n kube-system
kubectl create clusterrolebinding dashboard-admin --clusterrole=cluster-admin --serviceaccount=kube-system:dashboard-admin
kubectl describe secrets -n kube-system $(kubectl -n kube-system get secret | awk '/dashboard-admin/{print $1}')
data:image/s3,"s3://crabby-images/4689a/4689a2152a1622122475fcc3dfe3d14cb074fea3" alt=""
访问即可。