# 启动容器
启动容器有两种方式,一种是基于镜像新建一个容器并启动,另外一个是将在终止状态( exited
)的容器重新启动。
# 新建并启动
所需要的命令主要为 docker run
。
例如,下面的命令输出一个 Hello World
,之后终止容器。
$ docker run ubuntu:18.04 /bin/echo 'Hello world'
Hello world
1
2
2
这跟在本地直接执行 /bin/echo 'hello world'
几乎感觉不出任何区别。
下面的命令则启动一个 bash
终端,允许用户进行交互。
$ docker run -t -i ubuntu:18.04 /bin/bash
root@af8bae53bdd3:/#
1
2
2
其中, -t
选项让 Docker
分配一个伪终端( pseudo-tty
)并绑定到容器的标准输入上, -i
则让容器的标准输入保持打开。
在交互模式下,用户可以通过所创建的终端来输入命令,例如
root@af8bae53bdd3:/# pwd
/
root@af8bae53bdd3:/# ls
bin boot dev etc home lib lib64 media mnt opt proc root run sbin srv sys tmp usr var
1
2
3
4
2
3
4
当利用 docker run
来创建容器时,Docker 在后台运行的标准操作包括:
- 检查本地是否存在指定的镜像,不存在就从
registry
下载 - 利用镜像创建并启动一个容器
- 分配一个文件系统,并在只读的镜像层外面挂载一层可读写层
- 从宿主主机配置的网桥接口中桥接一个虚拟接口到容器中去
- 从地址池配置一个
ip
地址给容器 - 执行用户指定的应用程序
- 执行完毕后容器被终止
# 启动已终止容器
可以利用 docker container start
命令,直接将一个已经终止( exited
)的容器启动运行。