在Debian上安装Kubernetes集群是一个相对直接的过程,但需要确保所有步骤都正确执行。以下是在Debian 12上安装Kubernetes集群的详细步骤:
硬件要求:
实验环境:
设置主机名及更新 hosts 文件:
hostnamectl
命令设置它们的主机名。/etc/hosts
文件中添加节点 IP 地址和主机名映射。关闭所有节点的 swap 分区:
sudo swapoff -a
命令关闭交换分区。/etc/fstab
文件永久禁用 swap。为 k8s 集群添加防火墙规则:
如果 Debian 系统已启用操作系统防火墙,请在主控节点和工作节点上分别允许以下端口:
sudo ufw allow 6443/tcp
sudo ufw allow 2379/tcp
sudo ufw allow 2380/tcp
sudo ufw allow 10250/tcp
sudo ufw allow 10251/tcp
sudo ufw allow 10252/tcp
sudo ufw allow 10255/tcp
sudo ufw reload
在所有节点上安装 containerd 运行时:
在所有节点上设置内核参数:
sudo tee /etc/modules-load.d/containerd.conf <<EOF
overlaybr_netfilter
EOF
sudo modprobe overlay
sudo modprobe br_netfilter
sudo tee /etc/sysctl.d/99-kubernetes-k8s.conf <<EOF
net.bridge.bridge-nf-call-iptables = 1
net.ipv4.ip_forward = 1
EOF
sudo sysctl --system
安装 containerd:
sudo apt update
sudo apt install -y containerd
添加 Kubernetes apt 仓库:
安装必要的包:
sudo apt install -y apt-transport-https curl
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
安装 kubernetes 工具:
安装 kubelet、kubeadm 和 kubectl:
sudo apt install -y kubelet kubeadm kubectl
sudo apt-mark hold kubelet kubeadm kubectl
使用 kubeadm 安装 Kubernetes 集群:
在主节点上初始化集群:
sudo kubeadm init --apiserver-advertise-address=<master-node-ip> --image-repository registry.aliyuncs.com/google_containers --kubernetes-version v1.23.0 --control-plane-endpoint <master-node-ip>:6443 --service-cidr=10.100.0.0/16 --token-ttl 0 --pod-network-cidr=10.244.0.0/16
在主节点上配置 kubectl:
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
使用 Calico 设置 pod 网络:
下载并应用 Calico 配置文件:
wget https://raw.githubusercontent.com/projectcalico/calico/v3.26.1/manifests/calico.yaml
kubectl apply -f calico.yaml
如果防火墙已启用,开放 Calico 所需端口:
sudo ufw allow 179/tcp
sudo ufw allow 4789/udp
sudo ufw allow 51820/udp
sudo ufw allow 51821/udp
sudo ufw reload
验证集群安装:
检查集群状态:
kubectl get nodes
部署一个示例应用程序(如 Nginx)以验证集群功能:
kubectl create deployment nginx-app --image=nginx --replicas=2
kubectl expose deployment nginx-app --name=nginx-web-svc --type=NodePort --port=80 --target-port=80
kubectl describe svc nginx-web-svc
通过以上步骤,您可以在 Debian 12 上成功安装和配置一个 Kubernetes 集群。请确保每一步都正确执行,以避免不必要的错误。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>