以下是在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,则表示集群部署成功。