摘自:
在使用docker建立了容器之後,大家比較關心的就是如何進入該容器了,其實進入docker容器有好幾多種方式,這裡我們就講一下常用的幾種進入docker容器的方法。
進入docker容器比較常見的幾種做法如下:
docker提供了attach命令來進入docker容器。
接下來我們建立乙個守護態的docker容器,然後使用docker attach命令進入該容器。
$ sudo docker run -itd ubuntu:14.04 /bin/bash
然後我們使用docker ps檢視到該容器資訊,接下來就使用docker attach進入該容器
$ sudo docker attach 44fc0f0582d9
可以看到我們已經進入到該容器中了。
但在,使用該命令有乙個問題。當多個視窗同時使用該命令進入該容器時,所有的視窗都會同步顯示。如果有乙個視窗阻塞了,那麼其他視窗也無法再進行操作。
因為這個原因,所以docker attach命令不太適合於生產環境,平時自己開發應用時可以使用該命令。
在生產環境中排除了使用docker attach命令進入容器之後,相信大家第乙個想到的就是ssh。在映象(或容器)中安裝ssh server,這樣就能保證多人進入
容器且相互之間不受干擾了,相信大家在當前的生產環境中(沒有使用docker的情況)也是這樣做的。但是使用了docker容器之後不建議使用ssh進入到docker容
為什麼不需要在 docker 容器中執行 sshd
在了解了什麼是nsenter之後,系統預設將我們需要的nsenter安裝到主機中
如果沒有安裝的話,按下面步驟安裝即可(注意是主機而非容器或映象)
具體的安裝命令如下:
$ wget
$ 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之後可以檢視一下該命令的使用。
nsenter可以訪問另乙個程序的命名空間。所以為了連線到某個容器我們還需要獲取該容器的第乙個程序的pid。可以使用docker inspect命令來拿到該pid。
docker inspect命令使用如下:
$ sudo docker inspect --help
inspect命令可以分層級顯示乙個映象或容器的資訊。比如我們當前有乙個正在執行的容器
可以使用docker inspect來檢視該容器的詳細資訊。
由其該資訊非常多,此處只擷取了其中一部分進行展示。如果要顯示該容器第乙個進行的pid可以使用如下方式
在拿到該程序pid之後我們就可以使用nsenter命令訪問該容器了。
$ sudo nsenter --target 3326 --mount --uts --ipc --net --pid
$ sudo nsenter --target 3326 --mount --uts --ipc --net --pid
其中的3326即剛才拿到的程序的pid
四、使用docker exec進入docker容器
除了上面幾種做法之外,docker在1.3.x版本之後還提供了乙個新的命令exec用於進入容器,這種方式相對更簡單一些,下面我們來看一下該命令的使用:
接下來我們使用該命令進入乙個已經在執行的容器
$ sudo docker ps
$ sudo docker exec -it 775c7c9ee1e1 /bin/bash
分類: docker
Docker容器進入的4種方式
在使用docker建立了容器之後,大家比較關心的就是如何進入該容器了,其實進入docker容器有好幾多種方式,這裡我們就講一下常用的幾種進入docker容器的方法。進入docker容器比較常見的幾種做法如下 docker提供了attach命令來進入docker容器。接下來我們建立乙個守護態的dock...
Docker容器進入的4種方式
在使用docker建立了容器之後,大家比較關心的就是如何進入該容器了,其實進入docker容器有好幾多種方式,這裡我們就講一下常用的幾種進入docker容器的方法。進入docker容器比較常見的幾種做法如下 docker提供了attach命令來進入docker容器。接下來我們建立乙個守護態的dock...
Docker容器進入的4種方式
在使用docker建立了容器之後,大家比較關心的就是如何進入該容器了,其實進入docker容器有好幾多種方式,這裡我們就講一下常用的幾種進入docker容器的方法。進入docker容器比較常見的幾種做法如下 docker提供了attach命令來進入docker容器。接下來我們建立乙個守護態的dock...