目录
[四、部署worker node](#四、部署worker node)
实验环境
|--------|---------------|-------------------|
| 主机名 | IP | 角色 |
| docker | 192.168.67.10 | harbor |
| k8s1 | 192.168.67.11 | control-plane |
| k8s2 | 192.168.67.12 | control-plane |
| k8s3 | 192.168.67.13 | control-plane |
| k8s4 | 192.168.56.14 | haproxy,pacemaker |
| k8s5 | 192.168.67.15 | haproxy,pacemaker |
| k8s6 | 192.168.67.16 | worker node |
一、haproxy负载均衡
配置软件仓库
vim yyl.repo
#高可用的
[HighAvailability]
name=rhel7.6 HighAvailability
baseurl=file:///media/addons/HighAvailability
gpgcheck=0
data:image/s3,"s3://crabby-images/9cd06/9cd067867ccc4867dd0b4cf3e30ce2a5f256bd83" alt=""
下载软件
yum install -y haproxy net-tools
data:image/s3,"s3://crabby-images/a957d/a957de76bbd0c4119cad6f7d8106c645746736c4" alt=""
编辑配置文件
data:image/s3,"s3://crabby-images/85494/854948f239542cb0399959fb40f92a9ac0108a0e" alt=""
测试:
data:image/s3,"s3://crabby-images/48eab/48eab1c6257e7e4ac73708c3353b8c69aea54166" alt=""
测试成功后关闭服务,不要设置自启动
data:image/s3,"s3://crabby-images/11b1c/11b1c6339852ae5ab8269648cac3d12d59129ffe" alt=""
二、pacemaker高可用
同步配置文件
scp yyl.repo k8s5:/etc/yum.repos.d/
安装软件
yum install -y pacemaker pcs psmisc policycoreutils-python
两个节点都要
启动pcsd服务 设置用户密码 节点认证
systemctl enable --now pcsd.service
ssh k8s5 systemctl enable --now pcsd.service
echo westos | passwd --stdin hacluster
ssh k8s6 'echo westos | passwd --stdin hacluster'
pcs cluster auth k8s4 k8s5
data:image/s3,"s3://crabby-images/e4b5c/e4b5c155972eeced47942684bc261699cc571b6f" alt=""
创建集群
pcs cluster setup --name mycluster k8s5 k8s4
data:image/s3,"s3://crabby-images/4819d/4819d185cd065a7245d6ad5b6535f81f12197825" alt=""
启动集群
pcs cluster start --all
data:image/s3,"s3://crabby-images/79ca1/79ca16357992188197643c9da5919b51b3a1e779" alt=""
集群自启动
pcs cluster enable --all
禁用stonith
pcs property set stonith-enabled=false
data:image/s3,"s3://crabby-images/bbea5/bbea5e82d1b2e178f853d52b20af34aff92d07ac" alt=""
添加集群资源
pcs resource create vip ocf:heartbeat:IPaddr2 ip=192.168.67.200 op monitor interval=30s
pcs resource create haproxy systemd:haproxy op monitor interval=60s
pcs resource group add hagroup vip haproxy
测试
pcs node standby
资源全部迁移到k8s5 恢复:
pcs node unstandby
data:image/s3,"s3://crabby-images/e1889/e18893a1df222c963e0826d09df8d3644183340a" alt=""
测试:
data:image/s3,"s3://crabby-images/6a86f/6a86f1e0f064d1144589e58b4f1ed11c2f64c71b" alt=""
三、部署control-plane
k8s1、k8s2、k8s3在配置前需要重置节点
kubeadm reset
kubeadm reset --cri-socket unix:///var/run/cri-dockerd.sock
kubeadm reset --cri-socket unix:///var/run/cri-dockerd.sock
cd /etc/cni/net.d 初始化需要清除
rm -fr *
reboot 可以使iptable 和 ipvs 策略被自动清除
加载内核模块
modprobe overlay
modprobe br_netfilter
生成初始化配置文件
kubeadm config print init-defaults > kubeadm-init.yaml
修改配置
初始化集群
kubeadm init --config kubeadm-init.yaml --upload-certs
data:image/s3,"s3://crabby-images/3111b/3111b851420ada388f4661164ec2f3a34d1b0c41" alt=""
部署网络组件
kubectl apply -f calico.yaml
data:image/s3,"s3://crabby-images/97eac/97eacd7438d618eacadc23aca4020c131c2b7a4b" alt=""
添加其它control-plane节点
kubeadm join 192.168.56.200:6443 --token abcdef.0123456789abcdef --discovery-token-ca-cert-hash sha256:51184d632ecb2f9e6c7f82b064e07c01974924d359eb98035aae7ce98e56d60d --control-plane --certificate-key cb28e3d92a419945a34a6a2d1db49c80fbf5d8275c28e40f8c7e0450a9ad8fb5
data:image/s3,"s3://crabby-images/2628f/2628ffe19600382c80663dae8ecf790e8e8ef46b" alt=""
四、部署worker node
新添加的节点需要初始化配置
-
禁用selinux、firewalld、swap分区
-
部署containerd
-
安装kubelet、kubeadm、kubectl
-
配置内核模块
禁用swapswapoff -a
vim /etc/fstab
安装containerd、kubelet、kubeadm、kubectl 从其它节点拷贝repo文件
scp k8s.repo docker.repo k8s6:/etc/yum.repos.d/
yum install -y containerd.io kubeadm-1.24.17-0 kubelet-1.24.17-0 kubectl-1.24.17-0
自启动服务
systemctl enable --now containerd
systemctl enable --now kubelet
拷贝containerd的配置文件
scp -r * k8s6:/etc/containerd/
重启服务:
systemctl restart containerd
crictl config runtime-endpoint unix:///run/containerd/containerd.sock
crictl pull myapp:v1
data:image/s3,"s3://crabby-images/9a6d7/9a6d79886a0ff6562290bab2437ff79201df4c74" alt=""
配置内核模块:
cd /etc/sysctl.d/
scp docker.conf k8s7:/etc/sysctl.d/
modprobe overlay
modprobe br_netfilter
sysctl --system
添加worker节点
kubeadm join 192.168.56.200:6443 --token abcdef.0123456789abcdef --discovery-token-ca-cert-hash sha256:8845bd441093179e02b51a239075a64b5386085bb702c11397c21abebb132d25
测试:
data:image/s3,"s3://crabby-images/034b0/034b01f8701fce18f213443f99f5de7ccf269860" alt=""