Kubernetes 是一个容器编排系统,能够帮助您管理和扩展 Docker 容器。下面是一个关于如何在 Ubuntu 系统上部署 Kubernetes 集群的详细指南。
1. 更新系统
首先,我们需要更新系统以确保所有的依赖包都是最新的。
sudo apt update && sudo apt upgrade -y
2. 关闭 Swap
Kubernetes 需要大量内存来运行 Pod。如果 Swap 缓冲区启用,可能会导致 Pod 因为 Swap 而被杀死。因此,我们需要关闭 Swap。
sudo swapoff -a
然后,我们编辑 /etc/fstab 将 Swap 文件注释掉,以防止系统启动时再次激活 Swap:
sudo sed -i '/ swap / s/^/#/' /etc/fstab
3. 加载必要的内核模块
Kubernetes 需要 OverlayFS 和 Br_netfilter 内核模块来运行。我们需要手动加载这些模块。
cat <<EOF | sudo tee /etc/modules-load.d/k8s.conf
overlay
br_netfilter
EOF
然后,我们执行以下命令来加载这些模块:
sudo modprobe overlay
sudo modprobe br_netfilter
4. 设置必要的 sysctl 参数
我们需要设置几个 sysctl 参数,以便 Kubernetes 能够正常工作。
cat <<EOF | sudo tee /etc/sysctl.d/k8s.conf
net.bridge.bridge-nf-call-iptables = 1
net.bridge.bridge-nf-call-ip6tables = 1
net.ipv4.ip_forward = 1
EOF
然后,我们执行以下命令来应用这些参数:
sudo sysctl --system /etc/sysctl.d/k8s.conf
5. 安装 Kubernetes
现在,我们可以开始安装 Kubernetes 了。我们需要使用 kubeadm 来初始化 Kubernetes 集群。
sudo apt-get install -y docker.io
sudo systemctl start docker
sudo systemctl enable docker
curl -sSL https://packages.cloud.google.com/apt/cloud-utils-stable.gpg | sudo apt-key add -
sudo apt update
sudo apt-get install -y kubeadm
kubeadm init --pod-network-cidr 192.168.0.0/16
然后,我们需要执行以下命令来应用 Kubernetes 配置:
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
6. 部署 Calico
Calico 是一个网络插件,可以帮助 Kubernetes 集群管理 Pod 的网络通信。
kubectl apply -f https://raw.githubusercontent.com/projectcalico/calico/v3.24.0/manifests/tigera-operator.yaml
kubectl apply -f https://raw.githubusercontent.com/projectcalico/calico/v3.24.0/manifests/calico-ccr.yaml
7. 部署 Kubernetes Dashboard
Kubernetes 提供了一个 web 控制台,可以帮助您管理集群。
kubectl create deployment kubernetes-dashboard --image=kubernetesui/dashboard:v2.0.4
kubectl expose deployment kubernetes-dashboard --type=NodePort --port=80
8. 部署其他组件
还需要部署其他组件,例如 CoreDNS、Metrics Server 等。
9. 验证集群状态
最后,我们可以使用以下命令来验证集群的状态:
kubectl get nodes
kubectl get pods -A