Olá, pessoal!
Hoje vamos demonstrar como podemos utilizar o Kubernetes como ferramenta de automatização, distribuição de carga, monitoramento e orquestração entre containers.
O Kubernetes é um sistema de código aberto que foi desenvolvido pelo Google para gerenciamento de aplicativos em containers através de múltiplos hosts de um cluster. Tem como principal objetivo facilitar a implantação de aplicativos baseados em microservices. Ele foi baseado na experiência do Google de muitos anos de trabalho com containers, adaptando-o para se trabalhar com Docker.
O sistema foi muito útil para ser utilizado até o Docker Swarm 1.0, pois disponibilizava muitos recursos que o Docker não disponibilizava até aquele momento, entre eles: balanceamento de carga e movimento de containers sem perda de dados.
A principal vantagem que se tem ao utilizar o Kubernetes é que você não está preso às limitações da API do Docker (o problema do Swarm). Você tem total liberdade, já que o Kubernetes não foi desenvolvido especialmente para o Docker, você pode trocar a sua estrutura de Docker para Rockets (Containers no CoreOS). Você pode escolher a simplicidade do Swarm ou o poder do Kubernetes.
Dentro do Kubernetes, possuímos alguns termos para determinadas funções:
- Minions: É o nome dado para cada host do cluster;
- Kubelet: Agente que roda nos hosts do cluster;
- Pods: É a menor unidade dentro de um cluster. Nada mais é do que containers rodando dentro de seu cluster de Kubernetes. Pode ser um container rodando nginx, php, apache etc…
- Replication Controller: É o responsável por manter um número determinado de pods em execução. No RC é onde você diz quantos containers de nginx, php, apache você desejá que fiquem rodando; caso um caia, o RC cria outra instância automaticamente;
- Services: É o responsável por atrelar uma faixa de IP para um determinado RC. Para que cada vez que o RC crie uma nova instância de pod, o mesmo inicie com um IP determinado pelo service.
- Namespace: Com o namespace você pode dividir seu Cluster de Kubernetes em dois ambientes, Produção e Teste, podendo limitar os recursos computacionais para ambos.
Agora vamos ver como podemos instalar e configurar o Kubernetes para que você use em seu ambiente da melhor maneira possível.
Para conseguirmos realizar todos os procedimento, vamos criar uma estrutura com quatro servidores:
- Node – Master (CentOS7)
- Node – Minion1 (CentOS7)
- Node – Minion2 (CentOS7)
- Node – Minion3 (CentOS7)
Agora vamos instalar alguns componentes em nosso servidor Master.
//Instalando o Kubernetes e o etcd (Serviço de descoberta) yum install kubernetes etcd -y // Vamos editar o conf do etcd para liberarmos as portas de acesso a esse serviço. Você vai ver que o arquivo de // conf possui diversas linhas comentadas, vamos tirar o comentário apenas dessas linhas: vi /etc/etcd/etcd.conf ETCD_NAME=default ETCD_DATA_DIR="/var/lib/etcd/default.etcd" ETCD_LISTEN_CLIENT_URLS="http://0.0.0.0:2379" ETCD_ADVERTISE_CLIENT_URLS="http://localhost:2379" //Agora vamos fazer a configuração da API do Kubernetes vi /etc/kubernetes/apiserver KUBE_API_ADDRESS="--address=0.0.0.0" KUBE_API_PORT="--port=8080" KUBELET_PORT="--kubelet_port=10250" KUBE_ETCD_SERVERS="--etcd_servers=http://127.0.0.1:2379" KUBE_SERVICE_ADDRESSES="--service-cluster-ip-range=10.254.0.0/16" KUBE_ADMISSION_CONTROL="--admission_control=NamespaceLifecycle,NamespaceExists,LimitRanger,SecurityContextDeny,ResourceQuota" KUBE_API_ARGS="" //Depois de mexer nos conf da API do Kubernetes e do etcd, vamos dar um start neles agora systemctl restart etcd systemctl restart kube-apiserver systemctl restart kube-controller-manager systemctl kube-scheduler etcdctl mk /atomic.io/network/config '{"Network":"172.17.0.0/16"}'
Agora nos servidores Minions, vamos executar os seguintes comandos:
yum -y install flannel kubernetes //Vamos editar o conf do flannel agora em /etc/sysconfig/flanneld FLANNEL_ETCD="http://IPMASTER:2379" //Editando o conf do Kubernetes para conectar na API do master. /etc/kubernetes/config KUBE_MASTER="--master=http://IPMASTER:8080" //Agora vamos editar o conf do serviço de cada minion, então em cada servidor você vai colocar o seu respectivo IP. /etc/kubernetes/kubelet KUBELET_ADDRESS="--address=0.0.0.0" KUBELET_PORT="--port=10250" KUBELET_HOSTNAME="--hostname_override=IPMINION" KUBELET_API_SERVER="--api_servers=http://IPMASTER:8080" KUBELET_ARGS="" systemctl restart kube-proxy systemctl restart kubelet systemctl restart docker systemctl restart flanneld
Agora, no server Master, é só executar:
//Você receberá o status de nossos nó kubectl get nodes
Por hoje é isso, pessoal! Em nosso próximo artigo vamos demonstrar como podemos criar aplicações altamente disponíveis dentro do nosso Kubernetes.
Espero ter ajudado e já sabe: tendo dúvidas, entre em contato conosco.
Abraço!