上一章我们学习了如何构建 Docker 镜像,并通过镜像运行容器。本章将深入讨论容器:学习容器的各种操作,容器各种状态之间如何转换,以及实现容器的底层技术。
运行容器
docker run
- CMD 指令。
- ENTRYPOINT 指令。
- 在
docker run
例如下面的例子:
容器启动时执行 pwd
,返回的 /
是容器中的当前目录。 执行 docker ps
或 docker container ls
咦,怎么没有容器?用 docker ps -a
或 docker container ls -a
-a
会显示所有状态的容器,可以看到,之前的容器已经退出了,状态为Exited
。
这种“一闪而过”的容器通常不是我们想要的结果,我们希望容器能够保持 runing 状态,这样才能被我们使用。
让容器长期运行
如何让容器保存运行呢?
因为容器的生命周期依赖于启动时执行的命令,只要该命令不结束,容器也就不会退出。
理解了这个原理,我们就可以通过执行一个长期运行的命令来保持容器的运行状态。例如执行下面的命令:
while
可见容器仍处于运行状态。不过这种方法有个缺点:它占用了一个终端。
我们可以加上参数 -d
容器启动后回到了 docker host 的终端。这里看到 docker 返回了一串字符,这是容器的 ID。通过 docker ps
现在我们有了两个正在运行的容器。这里注意一下容器的 CONTAINER ID
和 NAMES
CONTAINER ID
NAMES
字段显示容器的名字,在启动容器时可以通过 --name
对于容器的后续操作,我们需要通过 “长ID”、“短ID” 或者 “名称” 来指定要操作的容器。比如下面停止一个容器:
这里我们就是通过 “短ID” 指定了要停止的容器。
通过 while
这一次我们用 --name
指定了容器的名字。 我们还看到容器运行的命令是httpd-foreground
,通过 docker history
我们经常需要进到容器里去做一些工作,比如查看日志、调试、启动其他进程等。下一节学习如何进入容器内部。