ubuntu部署kubernetes

80 阅读2分钟

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