Я начинаю работать с Docker. Я использую базовый образ WordPress и docker-compose.
Я пытаюсь войти по ssh в один из контейнеров, чтобы проверить файлы/каталоги, которые были созданы во время первоначальной сборки. Я попытался выполнить команду docker-compose run containername ls -la
, но это ничего не дало. Даже если бы это и помогло, я бы предпочел иметь консоль, в которой я могу просматривать структуру каталогов, а не выполнять одну команду. Какой правильный способ сделать это с помощью Docker?
docker attach
позволит вам подключиться к вашему контейнеру Docker, но это не совсем то же самое, что ssh
. Например, если в контейнере запущен веб-сервер, docker attach
, скорее всего, подключит вас к stdout процесса веб-сервера. Это не обязательно даст вам оболочку.
Команда docker exec
- это, вероятно, то, что вы ищете; она позволит вам выполнять произвольные команды внутри существующего контейнера. Например:
docker exec -it <mycontainer> bash
Конечно, команда, которую вы выполняете, должна существовать в файловой системе контейнера.
В приведенной выше команде <mycontainer>
- это имя или ID целевого контейнера. Не имеет значения, используете ли вы 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: <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
Я могу сделать то же самое, выполнив:
$ docker exec -it d2d4a89aaee9 ip addr
Аналогично, я могу запустить оболочку в контейнере;
$ docker exec -it web sh
/ # echo This is inside the container.
This is inside the container.
/ # exit
$
Чтобы установить bash в запущенный контейнер, введите следующее:
docker exec -t -i container_name /bin/bash
Допустим, по собственным причинам вы действительно хотите использовать SSH. Это займет несколько шагов, но это можно сделать. Вот команды, которые нужно выполнить внутри контейнера, чтобы настроить его...
apt-get update
apt-get install openssh-server
mkdir /var/run/sshd
chmod 0755 /var/run/sshd
/usr/sbin/sshd
useradd --create-home --shell /bin/bash --groups sudo username ## includes 'sudo'
passwd username ## Enter a password
apt-get install x11-apps ## X11 demo applications (optional)
ifconfig | awk '/inet addr/{print substr($2,6)}' ## Display IP address (optional)
Теперь вы можете даже запускать графические приложения (если они установлены в контейнере), используя переадресацию X11 на SSH-клиент:
ssh -X username@IPADDRESS
xeyes ## run an X11 demo app in the client
Вот некоторые связанные ресурсы:
Примечание: этот ответ способствует инструмента я'вэ написано.
Я'ве создали контейнерных SSH-сервер, что вы можете 'палки' для любого запущенного контейнера. Таким образом, вы можете создавать композиции с каждого контейнера. Единственное требование заключается в том, что контейнер имеет Баш.
Следующий пример запустит SSH сервер, прикрепленный к контейнеру с именем 'мой-контейнер'.
docker run -d -p 2222:22 \
-v /var/run/docker.sock:/var/run/docker.sock \
-e CONTAINER=my-container -e AUTH_MECHANISM=noAuth \
jeroenpeeters/docker-ssh
ssh localhost -p 2222
При подключении к этой услуге по SSH (с помощью SSH-клиента на выбор) сеанс Баш будет запущен в контейнере с именем 'мой-контейнер'.
Дополнительные указатели и документации: https://github.com/jeroenpeeters/docker-ssh
Если вы'снова здесь ищу Докер сочинять-конкретный ответ, как я был, она обеспечивает простой способ без необходимости искать сгенерированный идентификатор контейнера.
докер-сочинять старпома
принимает имя сервиса согласно вашему докер-сочинять.файл YML
.
Поэтому, чтобы получить оболочки Bash для ваших 'веб' обслуживание, вы можете сделать:
$ docker-compose exec web bash
Если вы're, используя Docker на Windows и хотите получить доступ к оболочке контейнера, используйте это:
winpty docker exec -it <container_id> sh
Скорее всего, у вас уже есть [ГИТ Баш](https://git-for-windows.github.io/ установлен). Если вы Don'т, обязательно установите его.
В некоторых случаях изображения могут быть альпийские основе. В этом случае он будет бросать:
ПСД во время выполнения exec неудачу: exec неудачу: container_linux.перейти:348: начиная процесс контейнера, нанесенный на "Метод exec: \"в баш\" и: исполняемый файл не найден в $путь и": неизвестно
Потому что /Бен/Баш
не'т существуют. Вместо этого вы должны использовать:
docker exec -it 9f7d99aa6625 ash
или
docker exec -it 9f7d99aa6625 sh
Если контейнер уже завершился (возможно, из-за какой-то ошибки), вы можете сделать
$ docker run --rm -it --entrypoint /bin/ash image_name
или
$ docker run --rm -it --entrypoint /bin/sh image_name
или
$ docker run --rm -it --entrypoint /bin/bash image_name
чтобы создать новый контейнер и попасть снарядом в него. Поскольку вы указали --РМ, контейнер будет удален при выходе из оболочки.
Для подключения к УМК в контейнере Windows, используйте
docker exec -it d8c25fde2769 cmd
Где d8c25fde2769 - это идентификатор контейнера.
<Н1>решение GOINSIDE</Н1>
установите goinside
командная строка с:
sudo npm install -g goinside
и заходите внутрь контейнера Docker с правильным размером, терминал с:
goinside docker_container_name
<Н2>ответ</Н2>
Мы'вэ поставить этот фрагмент в ~/.профиль
:
goinside(){
docker exec -it $1 bash -c "stty cols $COLUMNS rows $LINES && bash";
}
export -f goinside
Не только это делает все смогли попасть внутрь работающего контейнера с:
goinside containername
Он также решает долго жил проблема о размерах фиксированного контейнера Docker Терминал. Что очень раздражает, если вы сталкиваетесь с ним.
Кроме того, если вы будете следовать Ссылка вы'll имеет окончания команду, ваши имена докер контейнер тоже.
Это просто!
Список все ваши образы Docker:
sudo docker images
На моей системе он показал следующий результат:
REPOSITORY TAG IMAGE ID CREATED VIRTUAL SIZE
bash latest 922b9cc3ea5e 9 hours ago
14.03 MB
ubuntu latest 7feff7652c69 5 weeks ago 81.15 MB
У меня два Докер изображения на компьютере. Позвольте'ы сказать, что я хочу запустить первый.
sudo docker run -i -t ubuntu:latest /bin/bash
Это даст вам контроль над терминалом контейнера. Теперь вы можете делать все виды операций оболочки внутри контейнера. Как делать команды ls
будет выводить все папки в корень файловой системы.
bin boot dev etc home lib lib64 media mnt opt proc root run sbin srv sys tmp usr var
Использование:
docker attach <container name/id here>
В другую сторону, хотя и есть опасность в том, чтобы использовать "прикрепить", но если вы <и>сочетание клавиш Ctrl</роз> + <и>в</КБД>, Чтобы выйти из сессии, вы также остановить контейнер. Если вы просто хотите, чтобы увидеть, что происходит, журналы-F используйте докер
.
:~$ docker attach --help
Usage: docker attach [OPTIONS] CONTAINER
Attach to a running container
Options:
--detach-keys string Override the key sequence for detaching a container
--help Print usage
--no-stdin Do not attach STDIN
--sig-proxy Proxy all received signals to the process (default true)
Используйте эту команду:
docker exec -it containerid /bin/bash
Чтобы проверить файлы, запустите докер Run-это <изображения> /бин/Баш
, чтобы получить интерактивный терминал. Список изображений может быть получено докер изображений. В отличие от
этого решения докер метод exec` работает также в случае, когда изображение не'т начать (или закрывается сразу после запуска).
docker exec
определенно будет решением. Простой способ работы с заданным вами вопросом - монтирование каталога внутри Docker в каталог локальной системы.
Таким образом, вы сможете мгновенно просматривать изменения в локальном пути.
docker run -v /Users/<path>:/<container path>
$ docker exec -it <Container-Id> /bin/bash
Или в зависимости от оболочки, она может быть
$ docker exec -it <Container-Id> /bin/sh
Вы можете получить контейнер-ИД через команду docker ПС`
-я
= интерактивные
-Т
= выделить псевдо-телетайп
Если у вас есть Докер, установленные с Kitematic
, вы можете использовать GUI. Откройте Kitematic от значок Настройки и в окне Kitematic выберите контейнер и нажмите на значок
метод exec`.
Вы можете увидеть журнал контейнер и контейнер (на вкладке Настройки) тоже в данном интерфейсе.
Я'вэ, созданных функция терминала для более легкого доступа к контейнеру'терминал С. Может быть, это's полезный, чтобы вы, ребята, как хорошо:
Так что в результате, вместо ввода:
docker exec -it [container_id] /bin/bash
вы'и напишу:
dbash [container_id]
Поместите следующие строки в ваш ~/.файл (или любой другой, который работает для вас), затем откройте новое окно терминала и наслаждаться ярлык:
#usage: dbash [container_id]
dbash() {
docker exec -it "$1" /bin/bash
}