以下是在Ubuntu上部署K8S的步骤:
sudo swapoff -a和sudo sed -i '/ swap / s/1/g' /etc/fstab禁用交换分区。设置主机名,如在主节点执行sudo hostnamectl set-hostname k8s-master,并在所有节点的/etc/hosts文件中添加节点IP和主机名映射。加载内核模块,执行cat <<EOF | sudo tee /etc/modules-load.d/k8s.conf overlay br_netfilter EOF和sudo modprobe overlay br_netfilter。设置网络参数,执行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。sudo apt-get install -y apt-transport-https ca-certificates curl software-properties-common,curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -,sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"。安装Docker,sudo apt-get update,sudo apt-get install -y docker-ce,并配置Docker使用systemd作为cgroup驱动。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-get update,sudo apt-get install -y kubelet kubeadm kubectl,并使用sudo apt-mark hold防止组件被升级。sudo kubeadm init --pod-network-cidr=10.244.0.0/16(可根据实际情况修改CIDR)。初始化完成后,配置kubectl,执行mkdir -p $HOME/.kube,sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config,sudo chown $(id -u):$(id -g) $HOME/.kube/config。kubectl apply -f https://docs.projectcalico.org/manifests/calico.yaml。kubeadm join 192.168.1.100:6443 --token <token> --discovery-token-ca-cert-hash sha256:<hash>,在工作节点上执行该命令即可加入集群。kubectl get nodes,若所有节点状态为Ready,则表示集群部署成功。