debian

Debian上Kubernetes安装的最佳实践指南

小樊
43
2025-12-15 02:34:48
栏目: 智能运维

Debian 上 Kubernetes 安装最佳实践指南

一 环境与前置准备

二 系统内核与网络参数

示例配置(所有节点执行):

# 加载模块
sudo tee /etc/modules-load.d/containerd.conf <<EOF
overlay
br_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.bridge.bridge-nf-call-ip6tables = 1
net.ipv4.ip_forward                 = 1
EOF
sudo sysctl --system

上述内核与网络设置是 Kubernetes 在 Linux 上的通用前置条件,能确保网桥流量进入 iptables 规则链并实现跨节点转发。

三 安装容器运行时 containerd

示例步骤(所有节点执行):

sudo apt-get update
sudo apt-get install -y containerd
sudo mkdir -p /etc/containerd
containerd config default | sudo tee /etc/containerd/config.toml
# 启用 systemd cgroup
sudo sed -i 's/SystemdCgroup \= false/SystemdCgroup \= true/g' /etc/containerd/config.toml
sudo systemctl restart containerd
sudo systemctl enable --now containerd

说明:Kubernetes 自 v1.24 起默认使用 containerd;若使用 Docker,需安装 cri-dockerd 并配置 kubelet 使用其 CRI 端点。

四 安装 kubeadm kubelet kubectl

示例步骤(所有节点执行):

sudo apt-get update
sudo apt-get install -y apt-transport-https ca-certificates curl gnupg
curl -fsSL https://packages.cloud.google.com/apt/doc/apt-key.gpg | sudo gpg --dearmor -o /usr/share/keyrings/kubernetes-archive-keyring.gpg
echo "deb [signed-by=/usr/share/keyrings/kubernetes-archive-keyring.gpg] https://apt.kubernetes.io/ kubernetes-xenial main" | sudo tee /etc/apt/sources.list.d/kubernetes.list
sudo apt-get update
sudo apt-get install -y kubelet kubeadm kubectl
sudo apt-mark hold kubelet kubeadm kubectl
sudo systemctl enable --now kubelet

说明:上述仓库与安装方式适用于 Debian 10+ 的 x86_64 环境;安装完成后 kubelet 会处于“等待控制平面就绪”的状态。

五 初始化控制平面与网络插件

示例步骤(master 节点执行):

# 初始化(示例 Pod CIDR,Flannel 使用 10.244.0.0/16;Calico 常见 192.168.0.0/16)
sudo kubeadm init --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

# 安装网络插件(二选一)
# Flannel
kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml

# Calico
kubectl apply -f https://docs.projectcalico.org/manifests/calico.yaml

# 验证
kubectl get nodes
kubectl get pods -A

说明:初始化命令的输出包含用于工作节点加入的完整命令,请妥善保存;网络插件必须在控制平面就绪后部署,否则节点会一直处于 NotReady 状态。

六 加入工作节点与防火墙端口

常用端口清单(示例):

UFW 示例(按需开启):

sudo ufw allow 6443/tcp
sudo ufw allow 2379: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

说明:端口放行范围与具体网络插件、云环境相关,生产环境建议采用最小暴露面策略并结合网络策略(NetworkPolicy)进行细粒度控制。

0
看了该问题的人还看了