sudo apt update && sudo apt upgrade -y
sudo swapoff -a
sudo sed -i '/ swap / s/1/g' /etc/fstab # 永久禁用
sudo hostnamectl set-hostname <节点名称> # 如k8s-master、k8s-node1
echo "<节点IP> <节点名称>" | sudo tee -a /etc/hosts # 示例:192.168.1.100 k8s-master
Kubernetes依赖容器运行时,推荐使用Docker(需兼容版本):
# 安装Docker依赖
sudo apt install -y apt-transport-https ca-certificates curl software-properties-common
# 添加Docker官方GPG密钥
curl -fsSL https://download.docker.com/linux/debian/gpg | sudo apt-key add -
# 添加Docker APT源
echo "deb [arch=amd64] https://download.docker.com/linux/debian $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list
# 安装Docker
sudo apt update
sudo apt install -y docker-ce docker-ce-cli containerd.io
# 启动Docker并设置开机自启
sudo systemctl start docker
sudo systemctl enable docker
配置Containerd(Kubeadm默认使用):
sudo mkdir -p /etc/containerd
sudo tee /etc/containerd/config.toml <<EOF
[plugins."io.containerd.grpc.v1.containerd"]
suspend_timeout = 2h
[plugins."io.containerd.grpc.v1.containerd.default_runtime"]
runtime_type = "runc"
runtime_root = "/run/containerd/runc"
EOF
sudo systemctl restart containerd
在所有节点上执行:
# 添加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
# 安装kubelet、kubeadm、kubectl
sudo apt update
sudo apt install -y kubelet kubeadm kubectl
# 锁定组件版本(避免自动升级)
sudo apt-mark hold kubelet kubeadm kubectl
在Master节点上执行(选择Pod网络CIDR,如Flannel需10.244.0.0/16):
sudo kubeadm init --pod-network-cidr=10.244.0.0/16
初始化完成后,会输出加入Worker节点的命令(含Token和CA证书哈希),需保存备用。
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
Kubernetes需要网络插件实现Pod间通信,推荐Flannel(轻量易用):
kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
验证网络插件是否运行:
kubectl get pods -n kube-system
在Worker节点上执行Master节点初始化时输出的kubeadm join命令(示例):
sudo kubeadm join 192.168.1.100:6443 --token abcdef.0123456789abcdef --discovery-token-ca-cert-hash sha256:123456789abcdef
在Master节点上执行:
# 查看节点状态(所有节点应为Ready)
kubectl get nodes
# 查看集群信息
kubectl cluster-info
# 部署测试应用(可选)
kubectl create deployment nginx --image=nginx --replicas=2
kubectl expose deployment nginx --type=NodePort --port=80 --target-port=80
kubectl get pods -o wide # 查看Pod分布
通过任意节点IP加NodePort(如http://<节点IP>:31743)访问Nginx,验证集群功能。
sudo apt install ntp),避免时间偏差导致集群异常;apt update && apt upgrade更新Kubernetes及相关组件,确保安全性。