Utilizando Docker em múltiplos ambientes
Docker host é o nome do ativo responsável por gerenciar ambientes Docker, nesse capítulo mostraremos como é possível criá-los e gerenciá-los em infraestruturas distintas, tais como máquina virtual, nuvem e máquina física.
Docker machine é a ferramenta usada para essa gerência distribuída, permite a instalação e gerência de docker hosts de forma fácil e direta.
Essa ferramenta é muito usada por usuários de sistema operacional “não linux”, como demonstraremos ainda, mas sua função não limita-se a esse fim, pois também é bastante usada para provisionar e gerenciar infraestrutura Docker na nuvem, tal como AWS, Digital Ocean e Openstack.
Como funciona
Antes de explicar como utilizar o docker machine, precisamos reforçar o conhecimento sobre a arquitetura do Docker.
Como demonstra a imagem acima, a utilização do Docker divide-se em dois serviços: o que roda em modo daemon, em background, chamado de Docker Host, responsável pela viabilização dos containers no kernel Linux; e, o cliente, que chamaremos de Docker client, responsável por receber comandos do usuário e traduzir em gerência do Docker Host.
Cada Docker client é configurado para se conectar a determinado Docker host e nesse momento o Docker machine entra em ação, pois viabiliza a automatização da escolha de configuração de acesso do Docker client a distintos Docker host.
O Docker machine possibilita utilizar diversos ambientes distintos apenas modificando a configuração do cliente para o Docker host desejado: basicamente modificar algumas variáveis de ambiente. Segue exemplo:
export DOCKER_TLS_VERIFY="1"
export DOCKER_HOST="tcp://192.168.99.100:2376"
export DOCKER_CERT_PATH="/Users/gomex/.docker/machine/machines/default"
export DOCKER_MACHINE_NAME="default"
Modificando essas quatro variáveis, o Docker client poderá utilizar um ambiente diferente rapidamente e sem precisar reiniciar qualquer serviço.
Criando ambiente
O Docker machine serve principalmente para criar ambientes, futuramente geridos por ele na troca automatizada de contexto de configuração, através da mudança de variáveis de ambiente, como explicado anteriormente.
Para criar o ambiente é necessário verificar se a infraestrutura que deseja criar tem algum driver com suporte a esse processo. Segue a lista de drivers disponíveis.
Máquina virtual
Para esse exemplo, usaremos o driver mais utilizado, o virtualbox, ou seja, precisamos de um virtualbox instalado na nossa estação para que esse driver funcione adequadamente.
Antes de criar o ambiente vamos entender como funciona o comando de criação do docker machine:
docker-machine create --driver=
Para o driver virtualbox temos alguns parâmetros que podem ser utilizados:
Parâmetro | Explicação |
---|---|
--virtualbox-memory | Especifica a quantidade de memória RAM que o ambiente pode utilizar. O valor padrão é 1024MB. (Sempre em MB) |
--virtualbox-cpu-count | Especifica a quantidade de núcleos de CPU que esse ambiente pode utilizar. O valor padrão é 1 |
--virtualbox-disk-size | Especifica o tamanho do disco que esse ambiente pode utilizar. O valor padrão é 20000MB (Sempre em MB) |
Como teste utilizamos o seguinte comando:
docker-machine create --driver=virtualbox --virtualbox-disk-size 30000 teste-virtualbox
O resultado desse comando é a criação de uma máquina virtual no virtualbox. A máquina terá 30GB de espaço em disco, 1 núcleo e 1GB de memória RAM.
Para validar se o processo aconteceu como esperado, basta utilizar o seguinte comando:
docker-machine ls
O comando acima é responsável por listar todos os ambientes que podem ser usados a partir da estação cliente.
Pra mudar de cliente basta utilizar o comando:
eval $(docker-machine env teste-virtualbox)
Executando o comando ls será possível verificar qual ambiente está ativo:
docker-machine ls
Inicie um container de teste pra testar o novo ambiente
docker container run hello-world
Caso deseje mudar para outro ambiente, basta digitar o comando abaixo, usando o nome do ambiente desejado:
eval $(docker-machine env <ambiente>)
Caso deseje desligar o ambiente, utilize o comando:
docker-machine stop teste-virtualbox
Caso deseje iniciar o ambiente, utilize o comando:
docker-machine start teste-virtualbox
Caso deseje remover o ambiente, utilize o comando:
docker-machine rm teste-virtualbox
Tratamento de problema conhecido: caso esteja utilizando Docker-machine no MacOS e por algum motivo a estação hiberne quando o ambiente virtualbox tenha iniciado, é possível que, no retorno da hibernação, o Docker host apresente problemas na comunicação com a internet. Orientamos a, sempre que passar por problemas de conectividade no Docker host com driver virtualbox, desligue o ambiente e reinicie como medida de contorno.
Nuvem
Para esse exemplo usamos o driver da nuvem mais utilizada, AWS. Para tanto, precisamos de uma conta na AWS para que esse driver funcione adequadamente.
É necessário que suas credenciais estejam no arquivo ~/.aws/credentials da seguinte forma:
[default]
aws_access_key_id = AKID1234567890
aws_secret_access_key = MY-SECRET-KEY
Caso não deseje colocar essas informações em arquivo, você pode especificar via variáveis de ambiente:
export AWS_ACCESS_KEY_ID=AKID1234567890
export AWS_SECRET_ACCESS_KEY=MY-SECRET-KEY
Você pode encontrar mais informações sobre credencial AWS nesse artigo.
Quando criamos um ambiente utilizando o comando docker-machine create, o mesmo é traduzido para AWS na criação uma instância EC2 e, em seguida é instalado todos os softwares necessários, automaticamente, no novo ambiente.
Os parâmetros mais utilizados na criação desse ambiente são:
Parâmetro | Explicação |
---|---|
--amazonec2-region | Informa qual região da AWS é utilizada para hospedar seu ambiente. O valor padrão é us-east-1. |
--amazonec2-zone | É a letra que representa a zona utilizada. O valor padrão é "a" |
--amazonec2-subnet-id | Informa qual a sub-rede utilizada nessa instância EC2. Precisa ter sido criada previamente. |
--amazonec2-security-group | Informa qual security group é utilizado nessa instância EC2. Precisa ter sido criado previamente |
--amazonec2-use-private-address | Será criada uma interface com IP privado, pois por default, só especifica uma interface com IP público |
--amazonec2-vpc-id | Informa qual o ID do VPC desejado para essa instância EC2. Precisa ter sido criado previamente. |
Como exemplo, usamos o seguinte comando de criação do ambiente:
docker-machine create --driver amazonec2 --amazonec2-zone a --amazonec2-subnet-id subnet-5d3dc191 --amazonec2-security-group docker-host --amazonec2-use-private-address --amazonec2-vpc-id vpc-c1d33dc7 teste-aws
Após executar o comando, basta esperar finalizar, é normal demorar um pouco.
Para testar o sucesso da ação, execute o comando abaixo:
docker-machine ls
Verifique se o ambiente chamado teste-aws existe na lista, caso positivo, utilize o comando abaixo para mudar o ambiente:
eval $(docker-machine env teste-aws)
Inicie um container de teste pra verificar o novo ambiente
docker container run hello-world
Caso deseje desligar o ambiente, utilize o comando:
docker-machine stop teste-aws
Caso deseje iniciar o ambiente, utilize o comando:
docker-machine start teste-aws
Caso deseje remover o ambiente, utilize o comando:
docker-machine rm teste-aws
Após removido do local, automaticamente removerá a instância EC2, provisionada na AWS.