Debian 系统上部署 Kubernetes 的常见问题解答
一 环境准备与系统要求
sudo swapoff -a,并注释 /etc/fstab 中的 swap 行,防止重启后恢复。overlay、br_netfilternet.bridge.bridge-nf-call-iptables=1、net.bridge.bridge-nf-call-ip6tables=1、net.ipv4.ip_forward=1二 容器运行时选择与安装
sudo apt install -y containerd && sudo systemctl enable --now containerdsudo mkdir -p /etc/containerd && containerd config default | sudo tee /etc/containerd/config.toml && sudo systemctl restart containerd三 APT 源与版本兼容
sudo rm /etc/apt/sources.list.d/kubernetes.listcurl -fsSL https://pkgs.k8s.io/core:/stable:/v1.28/deb/Release.key | sudo gpg --dearmor -o /etc/apt/keyrings/kubernetes-archive-keyring.gpgecho "deb [signed-by=/etc/apt/keyrings/kubernetes-archive-keyring.gpg] https://pkgs.k8s.io/core:/stable:/v1.28/deb/ /" | sudo tee /etc/apt/sources.list.d/kubernetes.listsudo apt update && sudo apt install -y kubeadm=1.28.* kubelet=1.28.* kubectl=1.28.*sudo apt-mark hold kubelet kubeadm kubectl四 初始化与网络插件
sudo kubeadm init --pod-network-cidr=10.244.0.0/16(如使用 Flannel,该 CIDR 为推荐值)。mkdir -p $HOME/.kube && sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config && sudo chown $(id -u):$(id -g) $HOME/.kube/configkubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.ymlkubectl apply -f https://docs.projectcalico.org/manifests/tigera-operator.yaml && kubectl apply -f https://docs.projectcalico.org/manifests/custom-resources.yamlkubeadm init 输出中的 kubeadm join … 命令在各节点执行。五 常见报错与快速排查
kubeadm init 阶段卡在拉取镜像。kubeadm config images list 查看所需镜像,配置国内镜像源或手动 docker pull 并重命名标签后再初始化。kubectl get nodes 显示 NotReady。kubelet 与容器运行时日志。kubectl 报证书/权限/配置错误。sudo journalctl -xeu kubelet、tail -f /var/log/syslog、dmesgkubectl cluster-info、kubectl get nodes -o wide、kubectl logs -n kube-system <pod>。