debian

Kubernetes在Debian上的部署工具有哪些

小樊
39
2025-11-01 03:55:00
栏目: 智能运维

Kubernetes在Debian上的核心部署工具:kubeadm
kubeadm是Debian系统上部署Kubernetes集群的官方推荐工具,主要用于自动化完成集群初始化、节点加入、组件配置等核心步骤。其优势在于标准化流程、跨平台兼容性及与Kubernetes版本的同步更新,是Debian环境下最常用的部署方式。

kubeadm部署Kubernetes的关键步骤(Debian环境)

  1. 准备工作

    • 硬件要求:至少2核CPU、2GB RAM、20GB空闲硬盘空间;
    • 系统要求:Debian 12(Bookworm)及以上版本(建议使用稳定版);
    • 网络配置:所有节点需配置静态IP,确保节点间网络互通(SSH免密登录更便捷);
    • 时间同步:安装并启用NTP服务(如systemd-timesyncd),避免因时间差导致集群组件异常。
  2. 安装依赖组件

    • Docker容器引擎:Kubernetes依赖容器运行时,Debian上常用Docker作为容器引擎。通过官方仓库安装Docker CE,并启动服务:
      sudo apt install -y apt-transport-https ca-certificates curl
      curl -fsSL https://download.docker.com/linux/debian/gpg | sudo apt-key add -
      echo "deb [arch=amd64] https://download.docker.com/linux/debian $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list
      sudo apt update && sudo apt install -y docker-ce docker-ce-cli containerd.io
      sudo systemctl start docker && sudo systemctl enable docker
      
    • 禁用Swap:Kubernetes要求节点禁用Swap分区,否则会导致kubelet无法正常启动:
      sudo swapoff -a
      sudo sed -i '/ swap / s/^\(.*\)$/#\1/g' /etc/fstab
      
    • 安装containerd:部分Kubernetes版本(如1.24+)默认使用containerd作为容器运行时,需额外配置:
      sudo apt install -y containerd
      sudo mkdir -p /etc/containerd
      sudo tee /etc/containerd/config.toml << EOF
      [plugins."io.containerd.grpc.v1.cri".containerd.runtimes.runc.options]
        Path = "/usr/local/bin/runc"
        RuntimeArgs = []
      EOF
      sudo systemctl daemon-reload && sudo systemctl enable --now containerd
      ```。  
      
      
  3. 安装Kubernetes核心工具

    • 添加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
      
    • 安装kubelet、kubeadm、kubectl(用于集群管理):
      sudo apt install -y kubelet kubeadm kubectl
      sudo apt-mark hold kubelet kubeadm kubectl  # 锁定版本,避免自动升级导致兼容性问题
      ```。  
      
      
  4. 初始化Master节点

    • 在主节点执行kubeadm init命令,指定Pod网络CIDR(如10.244.0.0/16,适配Flannel等网络插件):
      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
      ```。  
      
      
  5. 安装网络插件

    • Kubernetes需要网络插件实现Pod间通信,常用Flannel(轻量级、易部署):
      kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
      
    • 安装完成后,可通过kubectl get pods -n kube-system验证网络插件是否正常运行。
  6. 加入Worker节点

    • 在Master节点初始化时,会生成kubeadm join命令(包含Token和CA证书哈希),在Worker节点执行该命令即可加入集群:
      sudo kubeadm join <master-ip>:6443 --token <token> --discovery-token-ca-cert-hash sha256:<hash>
      
    • 加入后,Master节点的kubectl get nodes会显示Worker节点状态为Ready

补充说明

除kubeadm外,Debian上也可通过手动安装Kubernetes组件(如kube-apiserver、kube-controller-manager等)部署集群,但这种方式复杂度高、维护难度大,仅适用于定制化场景。kubeadm仍是Debian环境下最便捷、最推荐的部署工具

0
看了该问题的人还看了