首页 > 技术文章 > Docker--在Docker中运行应用

tingyugetc 2016-12-10 20:50 原文

Docker--在Docker中运行应用


一个交互式的容器

既然在Docker提供的是一个容器,底层支撑着一个基本的操作系统环境,那我们就可以通过Docker进入到容器内部与系统进行交互。

据我理解:Docker中的镜像就是一堆文件的集合,并不是像VM中的一个操作系统。镜像可以简单理解为是一堆可执行文件放在一个空的Image中。

就比如写了个helloWord的程序,经过静态编译后放在空的Image中便成了一个镜像,这个Image的大小就是二进制文件的大小。如果不是静态编译的话,就需要把相应的链接库放到镜像中相应的位置,这样才能使动态编译的程序能够成功调用链接库使得程序能够正确运行,否则会提示找不到文件。

Docker官方提供的ubuntu等基础镜像,就是把依赖的文件放在正确的位置,从而使得大部分程序可以正常运行。这和VM的镜像是完全不同的概念。

Docker之上运行的每个容器内的进程都是运行在宿主物理机上的,无论容器内的镜像是ubuntu还是centos都是运行在主机内核上的(容器内没有自己的内核),这样的话就会出现如果宿主主机内核不能满足某种特性那么容器内依赖此特性的应用程序就无法运行的情况。

让我们再次运行docker run,指定新的命令来运行容器。

➜  ~ docker run -t -i ubuntu:14.04 /bin/bash
root@58e2224c2e52:/#

我们能够看到命令行的提示符出现了差别,这就说明我们进入到了容器内部的镜像内。

在这里,我们制定了参数:-t -i分别意味着:

-t表示在容器内制定一个伪终端
-i表示允许我们对容器内的STDIN进行交互。

接着我们指定了在容器内运行的命令/bin/bash在容器内启动bash(因为终端默认运行bash所以此参数不需要也行)。
所以容器启动后便会进入新的终端,出现新的提示符。

➜  ~ docker run -t -i ubuntu:14.04
root@7cb295200f44:/# ls
bin   dev  home  lib64  mnt  proc  run   srv  tmp  var
boot  etc  lib   media  opt  root  sbin  sys  usr
root@7cb295200f44:/# pwd
/
root@7cb295200f44:/# ls
bin   dev  home  lib64  mnt  proc  run   srv  tmp  var
boot  etc  lib   media  opt  root  sbin  sys  usr
root@7cb295200f44:/# cd /home/
root@7cb295200f44:/home# ls
root@7cb295200f44:/home# cd
root@7cb295200f44:~#

熟悉的linux味道~

当需要退出容器的时候,输入命令exit便可以退出。一旦退出容器,容器便会停止。

推荐阅读