在Ubuntu上配置Kubernetes网络需完成以下关键步骤,以Calico插件为例:
sudo ufw disable(生产环境需配置精确规则)。sudo swapoff -a,并注释/etc/fstab中Swap相关行。sudo tee /etc/sysctl.d/k8s.conf <<EOF
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
net.ipv4.ip_forward = 1
EOF
sudo sysctl --system
sudo apt update
sudo apt install -y docker.io
sudo systemctl enable --now docker
curl -s https://packages.cloud.google.com/apt/doc/apt-key.gpg | sudo apt-key add -
echo "deb https://apt.kubernetes.io/ kubernetes-xenial main" | sudo tee /etc/apt/sources.list.d/kubernetes.list
sudo apt update
sudo apt install -y kubelet kubeadm kubectl
sudo apt-mark hold kubelet kubeadm kubectl
在Master节点执行:
sudo kubeadm init --pod-network-cidr=192.168.0.0/16 # 指定Pod网络CIDR
记录输出的kubeadm join命令,用于后续加入节点。
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
kubectl apply -f https://docs.projectcalico.org/manifests/calico.yaml
其他插件(如Flannel、Weave)可参考对应文档修改安装命令。
kubectl get nodes,确认状态为Ready。参考来源: