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 init --pod-network-cidr=10.10.0.0/16 --apiserver-advertise-address=192.168.0.28
Inicializa o cluster Kubernetes especificando a rede de pods e o endereço do servidor API.
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
Configura o acesso ao cluster copiando o arquivo de configuração e ajustando permissões.
kubectl config view
kubectl get nodes
kubectl get pods -n kube-system
Exibe a configuração atual, os nodes do cluster e os pods em execução no namespace kube-system
.
watch -n1 kubectl get pods -n kube-system
Atualiza a cada segundo a lista de pods do namespace kube-system
.
kubectl apply -f https://github.com/weaveworks/weave/releases/download/v2.8.1/weave-daemonset-k8s.yaml
Instala o plugin de rede Weave Net para comunicação entre pods.
source <(kubectl completion bash)
echo "source <(kubectl completion bash)" >> /home/ubuntu/.bashrc
Habilita o autocomplete para o comando kubectl
no Bash.
sudo nano /etc/sysctl.conf
Adicione ou edite a linha:
net.ipv4.ip_forward = 1
sudo sysctl -p
Aplica as alterações do arquivo de configuração e reinicia o servidor.
Após reiniciar, valide se o CoreDNS inicializa corretamente e todos os componentes do cluster estão funcionando como esperado.