在Debian上快速安裝Kubernetes集群可以通過以下步驟實現。以下是一個基于kubeadm工具的詳細指南:
硬件要求:
系統設置:
/etc/hosts 文件,以便節點之間可以相互解析。更新系統:
sudo apt update
sudo apt upgrade -y
安裝Docker:
Kubernetes依賴Docker作為容器運行時,因此需要先安裝Docker。
sudo apt install docker.io -y
sudo systemctl start docker
sudo systemctl enable docker
禁用Swap:
為了確保Kubernetes集群的穩定運行,建議禁用Swap分區。
sudo swapoff -a
sudo sed -i '/ swap / s/1/g' /etc/fstab
添加Kubernetes APT倉庫:
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工具:
sudo apt install -y kubelet kubeadm kubectl
sudo apt-mark hold kubelet kubeadm kubectl
初始化Kubernetes集群:
在主節點上使用 kubeadm 初始化集群。
sudo kubeadm init --pod-network-cidr 10.244.0.0/16
初始化完成后,kubeadm 會顯示一個命令,用于將worker節點添加到集群中。記住這個命令,稍后會用到。
配置kubectl:
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
安裝網絡插件:
這里以Flannel為例,安裝Flannel網絡插件。
kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
將工作節點添加到集群:
在每個工作節點上運行從主節點初始化中獲得的join命令,將它們加入集群。
sudo kubeadm join <master-ip>:6443 --token <token> --discovery-token-ca-cert-hash sha256:<hash>
檢查集群狀態:
kubectl cluster-info
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
使用 curl 命令測試Nginx服務:
curl http://<node-ip>:31743
以上步驟涵蓋了在Debian系統中配置Kubernetes集群的基本流程。請根據您的實際網絡環境和需求調整配置。