A. Docker容器进入的4种方式(推荐最后一种)
在使用Docker创建容器后,如何进入容器是关键问题。以下将详细介绍几种常用的进入Docker容器的方法。
1. docker attach命令:此命令可以快速进入正在运行的容器。首先创建守护态容器,然后使用docker attach命令进入。在生产环境中,此方法存在同步操作问题,当多个窗口同时使用,一旦一个窗口阻塞,其他窗口也无法操作。因此,此方法不适用于生产环境,仅适用于个人开发应用场景。
2. SSH进入容器:在镜像或容器中安装SSH Server,保证多人进入容器互不影响。但使用Docker容器后,建议避免使用SSH,参阅相关文章了解原因。
3. nsenter命令:用于访问另一个进程的名称空间,可以连接到容器内的进程。需先安装nsenter,获取容器第一个进程的PID,使用docker inspect命令可获取。nsenter命令访问容器后,使用PID连接到该容器。有现成脚本可供使用,简化操作。
4. docker exec命令:Docker在1.3.X版本后新增的命令,提供了一种更简单的进入容器方式。直接使用docker exec命令进入运行中的容器,操作简便。
综上所述,Docker提供多种进入容器的方法,选择哪种方法取决于具体场景和需求。在选择进入方式时,需考虑生产环境的稳定性、并发操作问题以及操作简便性等因素。建议在个人开发场景下使用docker attach或docker exec命令,而对于生产环境则推荐使用更安全且互不影响的SSH方式。
B. docker下容器怎么执行命令
Docker中执行命令的方式主要分为两种。一种是直接进入容器的命令行界面。你可以使用命令:
su root docker run -i -t ubuntu:16.04 /bin/bash
其中,-i和-t的作用是帮助你进入交互模式,如果不加这部分,你将无法进入容器内部。/bin/bash的意思就是使用容器的命令行来输入命令。执行结果如下:
root@7d150a0fb029:/#
root后面跟的就是容器id,表明你已经进入容器,可以输入命令了。你可以输入一些常用命令试试,比如:
root@7d150a0fb029:/# docker run -i -t ubuntu:16.04 /bin/bash
结果输出了镜像的内核版本信息:
Linux version 4.13.0-36-generic (buildd@lgw01-amd64-033)(gcc version 5.4.020160609(Ubuntu5.4.0-6ubuntu1~16.04.9))#40~16.04.1-Ubuntu SMP Fri Feb 16 23:25:58 UTC 2018
通过exit可退出容器。
另一种方式是在后台执行命令。输入下面的代码:
docker run -d ubuntu:16.04 /bin/sh -c "while true; do echo hello world; sleep 1;done"
这里的-d表示的就是后台运行,这点可以直接通过docker run –help查看该命令的功能。这句话的意思就是在镜像的程序中添加引号内的代码,并在后台运行。
输出结果不会显示运行的结果,而是给出新建的容器id,这里说明一下,每次输入docker run命令都会新建一个容器,产生一个新的id。
输出结果如下:查看一下正在运行的容器:
root@cdl-XPS15R:/home/cdl# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
c7188be9bd7b ubuntu:16.04 "/bin/sh -c 'while t…" 13 seconds ago Up 11 seconds keen_vaughan1b6ba17f7df7
ubuntu:16.04 "/bin/bash" 2 minutes ago Exited(0)2 minutes ago cocky_noether7d150a0fb029
这里会发现,第一个容器的id和后台运行的容器id前几位一模一样,但是长度要长很多,其实是一样的,只不过通过ps命令打印输出时为了方便显示只显示了前几位。
如果想要进入后台运行的容器的命令行而不创建新的容器,只需要输入以下命令:
#Exec是进入已经存在的容器,run是创建新容器docker Exec-it c7188be9bd7b /bin/bash
输入哪个更长的id也是一样的效果:
docker Exec -it /bin/bash
输出结果都是:
root@c7188be9bd7b:/#