Как да вляза в обвивката на контейнер Docker'?

Започвам да работя с Docker. Използвам базовия образ на WordPress и docker-compose.

Опитвам се да вляза с ssh в един от контейнерите, за да проверя файловете/директориите, които са създадени по време на първоначалното изграждане. Опитах се да изпълня docker-compose run containername ls -la, но това не доведе до нищо. Дори и да го направи, предпочитам да имам конзола, в която мога да преглеждам структурата на директориите, вместо да изпълнявам една команда. Какъв е правилният начин да направя това с Docker?

Решение

docker attach ще ви позволи да се свържете с вашия контейнер Docker, но това всъщност не е същото като ssh. Ако контейнерът ви работи с уеб сървър например, docker attach вероятно ще ви свърже с stdout на процеса на уеб сървъра. Не е задължително да ви даде шел.

Командата docker exec вероятно е това, което търсите; тя ще ви позволи да изпълнявате произволни команди в съществуващ контейнер. Например:

docker exec -it  bash

Разбира се, всяка команда, която изпълнявате, трябва да съществува във файловата система на контейнера.

В горната команда `е името или идентификаторът на целевия контейнер. Няма значение дали използвате или неdocker compose; просто стартирайтеdocker ps` и използвайте или ID (шестнадесетичен низ, показан в първата колона), или името (показано в последната колона). Например, дадено:

$ docker ps
d2d4a89aaee9        larsks/mini-httpd   "mini_httpd -d /cont   7 days ago          Up 7 days                               web                 

Мога да стартирам:

$ docker exec -it web ip addr
1: lo:  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:  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

Мога да постигна същото нещо, като изпълня:

$ docker exec -it d2d4a89aaee9 ip addr

По същия начин мога да стартирам шел в контейнера;

$ docker exec -it web sh
/ # echo This is inside the container.
This is inside the container.
/ # exit
$
Коментари (8)

docker exec определено ще бъде решение. Лесен начин да се справим с въпроса, който сте задали, е като монтираме директорията в Docker към директорията на локалната система.

Така ще можете да виждате промените в локалния път незабавно.


docker run -v /Users/<path>:/
Коментари (2)

Друга възможност е да използвате nsenter.

PID=$(docker inspect --format {{.State.Pid}} )
nsenter --target $PID --mount --uts --ipc --net --pid
Коментари (4)