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!