ubuntu

Ubuntu如何部署Kubernetes

小樊
38
2025-06-29 15:41:18
栏目: 智能运维

在Ubuntu上部署Kubernetes集群是一个相对复杂的过程,需要按照一定的步骤进行。以下是一个详细的指南,帮助你在Ubuntu系统上安装Kubernetes。

环境准备

  1. 更新系统
sudo apt update && sudo apt upgrade -y
  1. 安装常用软件
sudo apt install -y vim lrzsz unzip wget net-tools tree bash-completion telnet
  1. 关闭交换分区
sudo swapoff -a
sudo sed -i '/swap/s//#/' /etc/fstab
  1. 开启IPv4转发和内核优化
sudo tee /etc/sysctl.d/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
  1. 时间同步
sudo apt install ntpdate
sudo ntpdate ntp.aliyun.com
  1. 安装Docker
sudo apt install -y docker.io
sudo systemctl start docker
sudo systemctl enable docker
  1. 卸载残留Docker软件包
for pkg in docker.io docker-doc docker-compose docker-compose-v2 podman-docker containerd runc; do
    sudo apt-get remove -y $pkg
done
  1. 更新软件包
sudo apt update
  1. 安装Docker依赖
sudo apt install -y ca-certificates
  1. 添加Docker官方GPG密钥
curl -s https://packages.cloud.google.com/apt/doc/apt-key.gpg | sudo apt-key add -
  1. 添加Docker软件源
echo "deb https://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker-ce.list
  1. 安装Docker
sudo apt update
sudo apt install -y docker-ce docker-ce-cli containerd.io
  1. 配置用户组(可选):
sudo groupadd dockers
sudo usermod -aG docker $USER
  1. 开启Docker
sudo systemctl start docker
sudo systemctl enable docker
  1. 配置Docker加速器(可选):
sudo mkdir -p /etc/docker
sudo nano /etc/docker/daemon.json <<EOF
{
    "registry-mirrors" : [ "https://mirrors.aliyuncs.com" ]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

部署Kubernetes集群

  1. 配置Kubernetes的APT源
curl -s https://packages.cloud.google.com/apt/doc/apt-key.gpg | sudo apt-key add -
echo "deb https://mirrors.cloud.google.com/apt/ kubernetes-xenial main" | sudo tee /etc/apt/sources.list.d/kubernetes.list
  1. 安装Kubeadm管理工具
sudo apt update
sudo apt install -y apt-transport-https ca-certificates curl
curl -s https://mirrors.cloud.google.com/apt/doc/apt-key.gpg | sudo apt-key add -
echo "deb https://mirrors.cloud.google.com/apt/ kubernetes-xenial main" | sudo tee /etc/apt/sources.list.d/kubernetes.list
sudo apt update
sudo apt install -y kubeadm=1.28.* kubelet=1.28.* kubectl=1.28.*
sudo apt-mark hold kubelet kubeadm kubectl
  1. 设置kubelet开机启动
sudo systemctl enable kubelet
sudo systemctl start kubelet
  1. 初始化主控节点
sudo kubeadm init --pod-network-cidr=192.168.0.0/16 --apiserver-advertise-address=<主节点IP> --control-plane-endpoint=<主节点IP或负载均衡地址>

成功初始化后,会生成一些命令,例如如何与Kubernetes集群互动,如何添加工作节点等。

  1. 配置kubectl
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
  1. 安装网络插件(如Calico)
kubectl apply -f https://raw.githubusercontent.com/projectcalico/calico/v3.27.0/manifests/calico.yaml
  1. 验证网络状态
kubectl get pods -n kube-system -l k8s-app=calico-node
  1. 添加工作节点

在工作节点上执行以下命令(使用主节点初始化后生成的命令):

sudo kubeadm join <主节点IP>:6443 --token <TOKEN> --discovery-token-ca-cert-hash sha256:<HASH>

至此,整个Kubernetes集群已经搭建完毕。接下来就可以着手规划应用服务的具体部署策略了。

0
看了该问题的人还看了