在使用Docker創建了容器之后,大家比較關心的就是如何進入該容器了,其實進入Docker容器有好幾多種方式,這里我們就講一下常用的幾種進入Docker容器的方法。
進入Docker容器比較常見的幾種做法如下:
1.使用docker attach
2.使用SSH
3.使用nsenter
4.使用exec
目前最為常用的是第四種,exec
一、使用docker attach進入Docker容器
創建一個守護態的Docker容器:
sudo docker run -itd ubuntu:16.04 /bin/bash
-d是detach,讓/bin/bash在后台運行
然后我們使用docker ps查看到該容器信息,接下來就使用docker attach進入該容器
sudo docker attach 44fc0f0582d9
可以看到我們已經進入到該容器中了。
但在,使用該命令有一個問題。當多個窗口同時使用該命令進入該容器時,所有的窗口都會同步顯示。如果有一個窗口阻塞了,那么其他窗口也無法再進行操作。
因為這個原因,所以docker attach命令不太適合於生產環境,平時自己開發應用時可以使用該命令。
二、使用SSH進入Docker容器
在生產環境中排除了使用docker attach命令進入容器之后,相信大家第一個想到的就是ssh。在鏡像(或容器)中安裝SSH Server,這樣就能保證多人進入容器且相互之間不受干擾了,相信大家在當前的生產環境中(沒有使用Docker的情況)也是這樣做的。但是使用了Docker容器之后不建議使用ssh進入到Docker容器內。關於為什么不建議使用,請參考如下文章:
為什么不需要在 Docker 容器中運行 sshd
三、使用nsenter進入Docker容器
nsenter:namespace enter。
需要安裝nsenter,如果沒有安裝的話,按下面步驟安裝即可(注意是主機而非容器或鏡像)
具體的安裝命令如下:
wget https://www.kernel.org/pub/linux/utils/util-linux/v2.24/util-linux-2.24.tar.gz
tar -xzvf util-linux-2.24.tar.gz
cd util-linux-2.24/
./configure --without-ncurses
make nsenter
sudo cp nsenter /usr/local/bin
nsenter可以訪問另一個進程的名稱空間。所以為了連接到某個容器我們還需要獲取該容器的第一個進程的PID。可以使用docker inspect命令來拿到該PID。
docker inspect container ID
sudo docker inspect 44fc0f0582d9
可以顯示出PID
最后利用nsenter:
sudo nsenter --target 3326 --mount --uts --ipc --net --pid
3326就是PID。
該方法的缺點在於步驟比較繁瑣。
四、docker exec進入Docker容器
這種方式相對更簡單一些,下面我們來看一下該命令的使用:
[c@localhost ~]$ docker exec --help
Usage: docker exec [OPTIONS] CONTAINER COMMAND [ARG...]
Run a command in a running container
Options:
-d, --detach Detached mode: run command in the background
--detach-keys string Override the key sequence for detaching a container
-e, --env list Set environment variables (default [])
--help Print usage
-i, --interactive Keep STDIN open even if not attached
--privileged Give extended privileges to the command
-t, --tty Allocate a pseudo-TTY
-u, --user string Username or UID (format: <name|uid>[:<group|gid>])
命令如下:
-it 標准輸入和關聯偽終端,-it后跟容器ID,/bin/bash是命令,表示在該容器中運行該命令
sudo docker exec -it 775c7c9ee1e1 /bin/bash
————————————————
版權聲明:本文為CSDN博主「hahachenchen789」的原創文章,遵循CC 4.0 by-sa版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/hahachenchen789/article/details/80523296