Introdução
O Docker é uma ferramenta de containerização popular usada para fornecer a aplicativos de software um sistema de arquivos que contém tudo o que precisam para serem executados. Usar containers Docker garante que o software se comporte da mesma maneira, independentemente de onde seja implantado, pois seu ambiente de execução é consistentemente rigoroso.
Neste tutorial, forneceremos uma visão geral breve da relação entre imagens Docker e containers Docker. Em seguida, daremos uma olhada mais detalhada em como executar, iniciar, parar e remover containers.
Visão Geral
Podemos pensar em uma imagem Docker como um modelo inerte usado para criar containers Docker. As imagens normalmente começam com um sistema de arquivos raiz e adicionam mudanças no sistema de arquivos e seus parâmetros de execução correspondentes em camadas ordenadas e somente leitura. Ao contrário de uma distribuição Linux típica, uma imagem Docker normalmente contém apenas o essencial necessário para executar a aplicação. As imagens não têm estado e não mudam. Em vez disso, elas formam o ponto de partida para os containers Docker.
As imagens ganham vida com o comando docker run
, que cria um contêiner adicionando uma camada de leitura e escrita sobre a imagem. Essa combinação de camadas de apenas leitura sobrepostas com uma camada de leitura e escrita é conhecida como um sistema de arquivos de união. Quando uma alteração é feita em um arquivo existente em um contêiner em execução, o arquivo é copiado do espaço de apenas leitura para a camada de leitura e escrita, onde as alterações são aplicadas. A versão na camada de leitura e escrita oculta o arquivo original, mas não o remove. As alterações na camada de leitura e escrita existem apenas dentro de uma instância de contêiner individual. Quando um contêiner é excluído, quaisquer alterações são perdidas a menos que medidas sejam tomadas para preservá-las.
Como Trabalhar com Contêineres Docker
Trabalhando com Containers
Cada vez que você usa o comando docker run
, ele cria um novo container a partir da imagem que você especificar. Isso pode ser uma fonte de confusão, então vamos dar uma olhada com alguns exemplos:
Passo 1: Criando Dois Containers
O seguinte comando docker run
irá criar um novo container usando a imagem base ubuntu
. -t
nos dará um terminal, e -i
nos permitirá interagir com ele. Vamos depender do comando padrão no arquivo Docker da imagem base do Ubuntu, bash
, para nos levar a um shell.
O prompt de linha de comando muda para indicar que estamos dentro do container como usuário root, seguido pelo ID do container com 12 caracteres.
Vamos fazer uma alteração escrevendo algum texto no diretório /tmp
do container e, em seguida, usar cat
para verificar se foi salvo com sucesso.
OutputExample1
Agora, vamos sair do container.
Os contêineres Docker param de ser executados assim que o comando que emitiram é concluído, então nosso contêiner parou quando saímos do shell bash. Se executarmos docker ps
, o comando para exibir contêineres em execução, não veremos o nosso.
OutputCONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
Se adicionarmos a sinalização -a
, que mostra todos os contêineres, parados ou em execução, então nosso contêiner aparecerá na lista:
OutputCONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
11cc47339ee1 ubuntu "/bin/bash" 6 minutes ago Exited (127) 8 seconds ago small_sinoussi
Quando o contêiner foi criado, ele recebeu seu ID de contêiner e um nome gerado aleatoriamente. Neste caso, 11cc47339ee1 é o ID do contêiner e small_sinoussi
é o nome gerado aleatoriamente. ps -a
mostra esses valores, assim como a imagem a partir da qual o contêiner foi construído (ubuntu
), quando o contêiner foi criado (seis minutos atrás
), e o comando que foi executado nele (/bin/bash
). A saída também fornece o status do contêiner (Exited
) e quanto tempo atrás o contêiner entrou nesse estado (6 segundos atrás
). Se o contêiner ainda estivesse em execução, veríamos o status “Up”, seguido de quanto tempo ele estava em execução.
Se executarmos novamente o mesmo comando, um novo contêiner é criado totalmente:
Podemos dizer que é um novo contêiner porque o ID no prompt de comando é diferente, e quando procuramos pelo nosso arquivo Exemplo1, não o encontraremos:
Outputcat: /tmp/Example1: No such file or directory
Isso pode fazer parecer que os dados desapareceram, mas esse não é o caso. Vamos sair do segundo contêiner agora para ver que ele, e nosso primeiro contêiner com o arquivo que criamos, estão ambos no sistema.
Quando listamos os contêineres novamente, ambos aparecem:
OutputCONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
6e4341887b69 ubuntu "/bin/bash" About a minute ago Exited (1) 6 seconds ago kickass_borg
11cc47339ee1 ubuntu "/bin/bash" 13 minutes ago Exited (127) 6 minutes ago small_sinoussi
Passo 2: Reiniciando o Primeiro Contêiner
Para reiniciar um contêiner existente, vamos usar o comando start
com a flag -a
para anexar a ele e a flag -i
para torná-lo interativo, seguido pelo ID ou nome do contêiner. Certifique-se de substituir o ID do seu contêiner no comando abaixo:
Nos encontramos novamente no prompt bash do contêiner e quando usamos cat
no arquivo que criamos anteriormente, ele ainda está lá.
OutputExample1
Agora podemos sair do contêiner:
Esta saída mostra que as alterações feitas dentro do contêiner persistem mesmo após pará-lo e reiniciá-lo. Somente quando o contêiner é removido é que o conteúdo é deletado. Este exemplo também ilustra que as alterações foram limitadas ao contêiner individual. Quando iniciamos um segundo contêiner, ele refletiu o estado original da imagem.
Passo 3: Excluindo Ambos os Contêineres
Criamos dois contêineres e concluiremos nosso breve tutorial excluindo-os. O comando docker rm
, que funciona apenas em contêineres parados, permite que você especifique o nome ou o ID de um ou mais contêineres, então podemos excluir ambos com o seguinte:
Output11cc47339ee1
kickass_borg
Ambos os recipientes e quaisquer alterações que fizemos dentro deles agora desapareceram.
Conclusão
Analisamos detalhadamente o comando docker run
para ver como ele cria automaticamente um novo recipiente cada vez que é executado. Também vimos como localizar um recipiente parado, iniciá-lo e conectar-se a ele. Se você deseja aprender mais sobre a gestão de recipientes, pode estar interessado no guia, Nomeando Recipientes Docker: 3 Dicas para Iniciantes.
Source:
https://www.digitalocean.com/community/tutorials/working-with-docker-containers