mirror of
https://github.com/MichaelCade/90DaysOfDevOps.git
synced 2025-01-10 07:06:38 +07:00
92 lines
2.6 KiB
Bash
92 lines
2.6 KiB
Bash
#! /bin/bash
|
||
|
||
# Variable Declaration
|
||
KUBERNETES_VERSION="1.23.3-00"
|
||
|
||
# disable swap
|
||
sudo swapoff -a
|
||
# keeps the swaf off during reboot
|
||
sudo sed -i '/ swap / s/^\(.*\)$/#\1/g' /etc/fstab
|
||
|
||
#Letting iptables see bridged traffic
|
||
lsmod | grep br_netfilter
|
||
sudo modprobe br_netfilter
|
||
|
||
cat <<EOF | sudo tee /etc/modules-load.d/k8s.conf
|
||
br_netfilter
|
||
EOF
|
||
|
||
cat <<EOF | sudo tee /etc/sysctl.d/k8s.conf
|
||
net.bridge.bridge-nf-call-ip6tables = 1
|
||
net.bridge.bridge-nf-call-iptables = 1
|
||
EOF
|
||
sudo sysctl --system
|
||
|
||
# containerd
|
||
cat <<EOF | sudo tee /etc/modules-load.d/containerd.conf
|
||
overlay
|
||
br_netfilter
|
||
EOF
|
||
|
||
sudo modprobe overlay
|
||
sudo modprobe br_netfilter
|
||
|
||
# Setup required sysctl params, these persist across reboots.
|
||
cat <<EOF | sudo tee /etc/sysctl.d/99-kubernetes-cri.conf
|
||
net.bridge.bridge-nf-call-iptables = 1
|
||
net.ipv4.ip_forward = 1
|
||
net.bridge.bridge-nf-call-ip6tables = 1
|
||
EOF
|
||
|
||
# Apply sysctl params without reboot
|
||
sudo sysctl --system
|
||
|
||
#Clean Install Docker Engine on Ubuntu
|
||
sudo apt-get remove docker docker-engine docker.io containerd runc
|
||
sudo apt-get update -y
|
||
sudo apt-get install -y \
|
||
apt-transport-https \
|
||
ca-certificates \
|
||
curl \
|
||
gnupg \
|
||
lsb-release
|
||
|
||
#Add Docker’s official GPG key:
|
||
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg
|
||
|
||
#set up the stable repository
|
||
echo \
|
||
"deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu \
|
||
$(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
|
||
|
||
#Install Docker Engine
|
||
sudo apt-get update -y
|
||
sudo apt-get install -y docker-ce docker-ce-cli containerd.io
|
||
|
||
#Configure containerd
|
||
sudo mkdir -p /etc/containerd
|
||
containerd config default | sudo tee /etc/containerd/config.toml
|
||
|
||
#restart containerd
|
||
sudo systemctl restart containerd
|
||
|
||
echo "ContainerD Runtime Configured Successfully"
|
||
|
||
#Installing kubeadm, kubelet and kubectl
|
||
sudo apt-get update -y
|
||
sudo apt-get install -y apt-transport-https ca-certificates curl
|
||
|
||
#Google Cloud public signing key
|
||
sudo curl -fsSLo /usr/share/keyrings/kubernetes-archive-keyring.gpg https://packages.cloud.google.com/apt/doc/apt-key.gpg
|
||
|
||
#Add Kubernetes apt repository
|
||
echo "deb [signed-by=/usr/share/keyrings/kubernetes-archive-keyring.gpg] https://apt.kubernetes.io/ kubernetes-xenial main" | sudo tee /etc/apt/sources.list.d/kubernetes.list
|
||
|
||
#Update apt package index, install kubelet, kubeadm and kubectl, and pin their version:
|
||
sudo apt-get update -y
|
||
|
||
sudo apt-get install -y kubelet kubectl kubeadm
|
||
|
||
sudo apt-mark hold kubelet kubeadm kubectl
|
||
|