Scripts/Deploy-Kubernetes-Manually.ps1 (58 lines of code) (raw):

param ( [string]$password, [string[]]$servers ) function Install-Kubernetes { param ( [string]$server ) Write-Host "Installing Kubernetes on $server" clusrun /nodes:$server 'sudo apt-get update && sudo apt-get install -y apt-transport-https curl' clusrun /nodes:$server 'echo deb [signed-by=/etc/apt/keyrings/kubernetes-apt-keyring.gpg] https://pkgs.k8s.io/core:/stable:/v1.28/deb/ / | sudo tee /etc/apt/sources.list.d/kubernetes.list' clusrun /nodes:$server 'sudo mkdir /etc/apt/keyrings' clusrun /nodes:$server 'curl -fsSL https://pkgs.k8s.io/core:/stable:/v1.28/deb/Release.key | sudo gpg --dearmor -o /etc/apt/keyrings/kubernetes-apt-keyring.gpg' clusrun /nodes:$server 'sudo apt-get update && sudo apt-get install -y kubelet kubeadm kubectl docker.io' clusrun /nodes:$server "wget https://packages.microsoft.com/config/ubuntu/20.04/packages-microsoft-prod.deb -O packages-microsoft-prod.deb" clusrun /nodes:$server "sudo dpkg -i packages-microsoft-prod.deb" clusrun /nodes:$server "rm packages-microsoft-prod.deb" clusrun /nodes:$server 'mkdir -p $HOME/.kube' clusrun /nodes:$server 'echo ''export PATH=$PATH:$HOME/KubernetesWrapper/net8.0'' >> ~/.profile' } function Init-Master-Node { param ( [string]$server ) clusrun /nodes:$server 'rm -f ~/.ssh/kube_key*' clusrun /nodes:$server 'ssh-keygen -t rsa -N """" -f ~/.ssh/kube_key' clusrun /nodes:$server 'sudo apt-get update && sudo apt-get install -y dotnet-sdk-8.0 && sudo apt install sshpass -y' clusrun /nodes:$server 'git clone https://github.com/Azure/hpcpack.git && cd hpcpack' clusrun /nodes:$server 'dotnet build ~/hpcpack/code/KubernetesWrapper/KubernetesWrapper.sln' clusrun /nodes:$server 'mkdir KubernetesWrapper && cp -r ~/hpcpack/code/KubernetesWrapper/KubernetesWrapper/bin/Debug/net8.0 ~/KubernetesWrapper' clusrun /nodes:$server 'sudo kubeadm init --pod-network-cidr=10.1.0.0/16' clusrun /nodes:$server 'sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config' clusrun /nodes:$server 'sudo chown $(id -u):$(id -g) $HOME/.kube/config' clusrun /nodes:$server 'kubectl create -f https://raw.githubusercontent.com/projectcalico/calico/v3.26.1/manifests/tigera-operator.yaml' clusrun /nodes:$server 'curl https://raw.githubusercontent.com/projectcalico/calico/v3.26.1/manifests/custom-resources.yaml -O' clusrun /nodes:$server 'sed -i ''s/cidr: 192\.168\.0\.0\/16/cidr: 10.1.0.0\/16/g'' custom-resources.yaml' clusrun /nodes:$server 'kubectl apply -f custom-resources.yaml' sleep 100 clusrun /nodes:$server 'kubectl taint nodes --all node-role.kubernetes.io/control-plane-' } foreach ($server in $servers) { Install-Kubernetes -server $server } Init-Master-Node -server $servers[0] $joinClusterCommand = clusrun /nodes:$($servers[0]) "sudo kubeadm token create --print-join-command" $joinClusterCommand = "sudo " + $joinClusterCommand[1] Write-Host joinClusterCommand Write-Host $joinClusterCommand for ($i = 1; $i -lt $servers.Length; $i++) { clusrun /nodes:$($servers[$i]) 'mkdir -p $HOME/.kube' clusrun /nodes:$($servers[0]) "sshpass -p $password ssh-copy-id -i ~/.ssh/kube_key.pub -o StrictHostKeyChecking=no $($servers[$i])" clusrun /nodes:$($servers[0]) "sshpass -p $password scp ~/.kube/config hpcadmin@$($servers[$i]):~/.kube" clusrun /nodes:$($servers[$i]) $joinClusterCommand clusrun /nodes:$($servers[$i]) "sudo apt-get update && sudo apt-get install -y dotnet-runtime-8.0" clusrun /nodes:$($servers[0]) "sshpass -p $password scp -r ~/KubernetesWrapper hpcadmin@$($servers[$i]):~/KubernetesWrapper" } New-HpcGroup -Name "Kubernetes" -ErrorAction SilentlyContinue Add-HpcGroup -Name "Kubernetes" -NodeName $servers