sudo ufw disable
Desativa o firewall UFW para evitar bloqueios de comunicação entre os componentes do cluster.
sudo swapoff -a
Desativa o uso de swap, pois o Kubernetes requer que o swap esteja desabilitado para funcionamento adequado.
sudo sed -i '/ swap / s/^\(.*\)$/#\1/g' /etc/fstab
Impede que o swap seja reativado automaticamente ao reiniciar o sistema.
sudo echo 1 > /proc/sys/net/ipv4/ip_forward
Habilita o encaminhamento de pacotes IPv4 para permitir comunicação entre pods.
cat <<EOF | sudo tee /etc/modules-load.d/k8s.conf
overlay
br_netfilter
EOF
sudo modprobe overlay
sudo modprobe br_netfilter
Configura e carrega os módulos overlay
e br_netfilter
para suportar redes em contêineres.
sudo sysctl --system
Aplica todas as configurações do kernel configuradas nos arquivos de configuração.
sudo apt-get update && sudo apt-get install -y apt-transport-https curl
Atualiza os repositórios e instala dependências necessárias.
curl -fsSL https://pkgs.k8s.io/core:/stable:/v1.30/deb/Release.key | sudo gpg --dearmor -o /etc/apt/keyrings/kubernetes-apt-keyring.gpg
Baixa e adiciona a chave de assinatura do repositório do Kubernetes.
echo 'deb [signed-by=/etc/apt/keyrings/kubernetes-apt-keyring.gpg] https://pkgs.k8s.io/core:/stable:/v1.30/deb/ /' | sudo tee /etc/apt/sources.list.d/kubernetes.list
Adiciona o repositório oficial do Kubernetes.
sudo apt-get update
sudo apt-get install -y kubelet kubeadm kubectl
sudo apt-mark hold kubelet kubeadm kubectl
Instala o kubelet, kubeadm e kubectl e impede que sejam atualizados automaticamente.
sudo systemctl enable --now kubelet
Habilita o kubelet para iniciar automaticamente no boot.
sudo apt-get update && sudo apt-get install -y apt-transport-https ca-certificates curl gnupg lsb-release
Instala dependências para configurar o Docker.
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg
Adiciona a chave de assinatura do repositório do Docker.
echo "deb [arch=amd64 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
Adiciona o repositório oficial do Docker.
sudo apt-get update && sudo apt-get install -y containerd.io
Instala o runtime containerd.
sudo containerd config default | sudo tee /etc/containerd/config.toml
sudo sed -i 's/SystemdCgroup = false/SystemdCgroup = true/g' /etc/containerd/config.toml
sudo systemctl restart containerd
Gera o arquivo de configuração padrão, ajusta para usar cgroups gerenciados pelo systemd e reinicia o containerd.
sudo systemctl status containerd
sudo systemctl enable --now kubelet
Verifica o status do containerd e habilita o kubelet.
sudo kubeadm join 192.168.0.101:6443 --token 8k5bex.fqbaekqoi136l4re --discovery-token-ca-cert-hash sha256:94713c894bd6442122f5757cc6d9a869bc19c53c98f8abef8c3132a2c7036670