diff --git a/container/README.md b/container/README.md index c7256b6..a429a15 100644 --- a/container/README.md +++ b/container/README.md @@ -1 +1,38 @@ # 容器 +##启动容器 +所需要的命令主要为`docker run` + +例如,下面的命令输出一个"Hello World",之后终止容器。 +``` +$ sudo docker run ubuntu:14.04 /bin/echo 'Hello world' +Hello world +``` + +下面的命令则启动一个bash终端,可以让用户进行交互。 +``` +$ sudo docker run -t -i ubuntu:14.04 /bin/bash +root@af8bae53bdd3:/# +``` +其中,`-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 +``` + +当利用`docker run`来创建容器时,Docker在后台运行的标准操作包括: + +* 检查本地是否存在指定的镜像,不存在就从公有仓库下载 +* 利用镜像创建并启动一个容器 +* 分配一个文件系统,并在只读的镜像层外面挂载一层可读写层 +* 从宿主主机配置的网桥接口中桥接一个虚拟接口到容器中去 +* 从地址池配置一个ip地址给容器 +* 执行用户指定的应用程序 + +##终止容器 + +当Docker容器中指定的应用终结时,容器也自动终止。 +例如用户通过`exit`命令或`Ctrl+d`来退出终端时,所创建的容器立刻终止。 diff --git a/container/daemon.md b/container/daemon.md new file mode 100644 index 0000000..5a876f8 --- /dev/null +++ b/container/daemon.md @@ -0,0 +1,24 @@ +##守护态运行 + +更多的时候,需要让Docker容器在后台以守护态(Daemonized)形式运行。此时,可以通过添加`-d`参数来实现。 + +例如下面的命令会在后台运行容器。 +``` +$ sudo docker run -d ubuntu:14.04 /bin/sh -c "while true; do echo hello world; sleep 1; done" +1e5535038e285177d5214659a068137486f96ee5c2e85a4ac52dc83f2ebe4147 +``` + +容器启动后会返回一个唯一的id,也可以通过`docker ps`命令来查看容器信息。 +``` +$ sudo docker ps +CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES +1e5535038e28 ubuntu:14.04 /bin/sh -c 'while tr 2 minutes ago Up 1 minute insane_babbage +``` +要获取容器的输出信息,可以通过`docker logs`命令。 +``` +$ sudo docker logs insane_babbage +hello world +hello world +hello world +. . . +``` diff --git a/container/rm.md b/container/rm.md new file mode 100644 index 0000000..0553165 --- /dev/null +++ b/container/rm.md @@ -0,0 +1,5 @@ +##终止容器 +可以使用`docker stop`来终止一个运行中的容器。 + +此外,当Docker容器中指定的应用终结时,容器也自动终止。 +例如对于上一章节中只启动了一个终端的容器,用户通过`exit`命令或`Ctrl+d`来退出终端时,所创建的容器立刻终止。 diff --git a/container/run.md b/container/run.md new file mode 100644 index 0000000..0c24f00 --- /dev/null +++ b/container/run.md @@ -0,0 +1,43 @@ +# 容器 +##启动容器 +所需要的命令主要为`docker run`。 + +例如,下面的命令输出一个"Hello World",之后终止容器。 +``` +$ sudo docker run ubuntu:14.04 /bin/echo 'Hello world' +Hello world +``` + +下面的命令则启动一个bash终端,可以让用户进行交互。 +``` +$ sudo docker run -t -i ubuntu:14.04 /bin/bash +root@af8bae53bdd3:/# +``` +其中,`-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 +``` + +当利用`docker run`来创建容器时,Docker在后台运行的标准操作包括: + +* 检查本地是否存在指定的镜像,不存在就从公有仓库下载 +* 利用镜像创建并启动一个容器 +* 分配一个文件系统,并在只读的镜像层外面挂载一层可读写层 +* 从宿主主机配置的网桥接口中桥接一个虚拟接口到容器中去 +* 从地址池配置一个ip地址给容器 +* 执行用户指定的应用程序 + + +容器的核心为所执行的应用程序,所需要的资源都是应用程序运行所必需的。除此之外,并没有其它的资源。可以在伪终端中查看进程信息。 +``` +root@ba267838cc1b:/# ps + PID TTY TIME CMD + 1 ? 00:00:00 bash + 11 ? 00:00:00 ps +``` +可见,容器中仅运行了指定的bash应用。这种特点使得Docker对资源的利用率极高,是货真价实的轻量级虚拟化。 diff --git a/container/stop.md b/container/stop.md new file mode 100644 index 0000000..0553165 --- /dev/null +++ b/container/stop.md @@ -0,0 +1,5 @@ +##终止容器 +可以使用`docker stop`来终止一个运行中的容器。 + +此外,当Docker容器中指定的应用终结时,容器也自动终止。 +例如对于上一章节中只启动了一个终端的容器,用户通过`exit`命令或`Ctrl+d`来退出终端时,所创建的容器立刻终止。