I' estou a começar a trabalhar com o Docker. I'm usando a imagem base do WordPress e o docker-compose.
I'estou tentando ssh em um dos containers para inspecionar os arquivos/diretórios que foram criados durante a construção inicial. Eu tentei rodar docker-compose run containername ls -la
, mas isso não fez't fazer nada. Mesmo que fizesse, I'preferia ter um console onde eu pudesse atravessar a estrutura de diretórios, ao invés de rodar um único comando. Qual é a maneira certa de fazer isso com o Docker?
O docker attach' irá permitir que você se conecte ao seu container Docker, mas isto não é realmente a mesma coisa que
ssh'. Se seu container está rodando um servidor web, por exemplo, o `docker attach' provavelmente o conectará ao stdout do processo do servidor web. Isto não lhe dará necessariamente um shell.
O comando docker exec
é provavelmente o que você está procurando; isto permitirá que você execute comandos arbitrários dentro de um container existente. Por exemplo, o comando `docker exec':
docker exec -it <mycontainer> bash
É claro que qualquer comando que você esteja executando deve existir no sistema de arquivos de contêineres.
No comando acima <mycontainer>
está o nome ou ID do recipiente alvo. Não importa se você está ou não utilizando docker compose'; basta executar
docker ps' e utilizar ou o ID (uma string hexadecimal exibida na primeira coluna) ou o nome (exibido na coluna final). Por exemplo, dado:
$ docker ps
d2d4a89aaee9 larsks/mini-httpd "mini_httpd -d /cont 7 days ago Up 7 days web
Eu posso correr:
$ docker exec -it web ip addr
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
inet 127.0.0.1/8 scope host lo
valid_lft forever preferred_lft forever
inet6 ::1/128 scope host
valid_lft forever preferred_lft forever
18: eth0: <BROADCAST,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP
link/ether 02:42:ac:11:00:03 brd ff:ff:ff:ff:ff:ff
inet 172.17.0.3/16 scope global eth0
valid_lft forever preferred_lft forever
inet6 fe80::42:acff:fe11:3/64 scope link
valid_lft forever preferred_lft forever
Eu poderia conseguir o mesmo, correndo:
$ docker exec -it d2d4a89aaee9 ip addr
Da mesma forma, eu poderia começar uma concha no recipiente;
$ docker exec -it web sh
/ # echo This is inside the container.
This is inside the container.
/ # exit
$
O docker exec
será definitivamente uma solução. Uma maneira fácil de trabalhar com a pergunta que você fez é montando o diretório dentro do Docker no diretório do sistema local***.
Para que você possa ver as mudanças no caminho local instantaneamente.
docker run -v /Users/<path>:/<container path>
Outra opção é usar nsenter.
PID=$(docker inspect --format {{.State.Pid}} <container_name_or_ID>)
nsenter --target $PID --mount --uts --ipc --net --pid