在CentOS上部署Kubernetes(k8s)时可能会遇到各种问题。以下是一些常见的步骤和故障排除方法,帮助你解决部署过程中遇到的问题。
部署步骤
-
准备工作
- 配置主机名:
hostnamectl set-hostname k8s-master
- 关闭SELinux和防火墙:
setenforce 0 systemctl stop firewalld && systemctl disable firewalld
- 关闭swap分区:
swapoff -a sed -i 's/.*swap.etc/fstab/#&/' /etc/fstab
- 配置Docker源并安装Docker:
yum install -y yum-utils device-mapper-persistent-data lvm2 yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo yum install -y docker-ce docker-ce-cli containerd.io systemctl start docker && systemctl enable docker
- 配置Kubernetes源并安装kubeadm、kubelet和kubectl:
cat <
/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 yum install -y kubelet-1.18.0 kubeadm-1.18.0 kubectl-1.18.0 systemctl enable kubelet && systemctl start kubelet
- 配置主机名:
-
初始化Master节点
kubeadm init --pod-network-cidr 10.244.0.0/16 --apiserver-advertise-address 192.168.1.100
-
配置kubectl
mkdir -p $HOME/.kube cp -i /etc/kubernetes/admin.conf $HOME/.kube/config chown $(id -u):$(id -g) $HOME/.kube/config
-
安装网络插件(如Flannel)
kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
-
加入Node到集群 在Node上运行初始化时生成的命令:
kubeadm join 192.168.1.100:6443 --token
--discovery-token-ca-cert-hash sha256:
故障排除
-
Pod无法正常启动
- 使用
kubectl get pods
检查Pod状态。 - 使用
kubectl describe pod
查看Pod详细信息。 - 检查资源配额、容器镜像可用性、Pod定义文件。
- 使用
-
Service无法访问
- 使用
kubectl get services
检查Service状态。 - 使用
kubectl describe service
查看Service详细信息。 - 检查Service指向的Pod是否存在、端口和协议配置、防火墙或网络策略。
- 使用
-
Node无法加入集群
- 使用
kubectl get nodes
检查Node状态。 - 在Node上运行
kubeadm reset
重置Node状态。 - 检查网络配置、系统配置、依赖软件和服务安装情况。
- 使用
-
控制平面组件无法启动
- 使用
kubectl get pods -n kube-system
检查控制平面组件状态。 - 使用
kubectl describe pod -n kube-system
查看Pod详细信息。 - 检查控制平面组件日志文件
/var/log/kubernetes/
。 - 检查控制平面组件配置文件,确保没有配置错误。
- 使用
常见问题及处理方法
-
内核参数错误
modprobe br_netfilter echo 1 > /proc/sys/net/bridge/bridge-nf-call-iptables echo 1 > /proc/sys/net/ipv4/ip_forward
-
Docker版本不匹配
- 安装指定版本的Docker和kubeadm:
yum remove kubelet kubeadm kubectl yum install -y kubeadm-1.15.1 kubectl-1.15.1 kubelet-1.15.1
- 安装指定版本的Docker和kubeadm:
-
Token过期
- 重新生成Token并加入节点:
kubeadm token create --print-join-command
- 重新生成Token并加入节点:
通过以上步骤和故障排除方法,你应该能够解决在CentOS上部署Kubernetes时遇到的大多数问题。如果问题仍然存在,建议查阅Kubernetes官方文档或社区论坛获取更多帮助。