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