天天看点

CentOS 6.5 使用docker 容器

docker 是一个linux 上的LXC 容器项目,是很轻量级的虚拟化技术。

docker虽然基于lxc技术(cgroup、namespace等),但是思路完全和lxc不一样。

lxc看起来更像是一个虚拟机,多用于操作系统级别的虚拟化,背后的哲学是 IAAS;

而docker看起来是一个程序,跑在沙箱里的程序,属于应用程序级别的虚拟化,背后的哲学是 PAAS。

RHEL 6.5 开始提供docker 支持,这里我们使用新出炉的 CentOS 6.5 x64 进行实验。

安装docker

1

<code>yum </code><code>install</code> <code>docker-io --enablerepo=epel</code>

1、下载官方制作的CentOS6.4镜像

<code>docker pull centos</code>

输出大致如下

2

3

<code>Pulling repository centos</code>

<code>539c0211cd76: Downloading 67.96 MB</code><code>/98</code><code>.56 MB (69%)</code>

<code>539c0211cd76: Download complete</code>

下载的镜像位于/var/lib/docker/devicemapper/mnt/539c0211cd76*/rootfs/

2、查看安装好的虚拟机

4

<code># docker images</code>

<code>输出如下</code>

<code>REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE</code>

<code>centos              6.4                 539c0211cd76        8 months ago        300.6 MB (virtual 300.6 MB)</code>

3、接下来我们在centos 6.4的环境下执行一个top命令,然后查看输出

5

6

7

8

9

10

11

12

13

14

15

16

17

<code># ID=$( docker run -d centos /usr/bin/top -b)</code>

<code># docker attach $ID</code>

<code>top</code> <code>- 23:30:50 up 47 min,  0 </code><code>users</code><code>,  load average: 0.14, 0.44, 0.53</code>

<code>Tasks:   1 total,   1 running,   0 sleeping,   0 stopped,   0 zombie</code>

<code>Cpu(s):  4.6%us,  1.0%sy,  0.0%ni, 91.6%</code><code>id</code><code>,  2.8%wa,  0.0%hi,  0.0%si,  0.0%st</code>

<code>Mem:   7963636k total,  3795180k used,  4168456k </code><code>free</code><code>,   120628k buffers</code>

<code>Swap:  2097144k total,        0k used,  2097144k </code><code>free</code><code>,  1870656k cached</code>

<code>  </code><code>PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND    </code>

<code>    </code><code>1 root      20   0 14896 1180  984 R  0.0  0.0   0:00.03 </code><code>top</code>        

<code>top</code> <code>- 23:30:53 up 47 min,  0 </code><code>users</code><code>,  load average: 0.13, 0.43, 0.53</code>

<code>Cpu(s):  4.0%us,  0.9%sy,  0.0%ni, 93.7%</code><code>id</code><code>,  1.3%wa,  0.0%hi,  0.0%si,  0.0%st</code>

<code>Mem:   7963636k total,  3790700k used,  4172936k </code><code>free</code><code>,   120644k buffers</code>

<code>Swap:  2097144k total,        0k used,  2097144k </code><code>free</code><code>,  1866336k cached</code>

<code>    </code><code>1 root      20   0 14896 1180  984 R  0.0  0.0   0:00.03 </code><code>top</code>

4、杀死这个虚拟机

<code># docker stop $ID</code>

5、进入虚拟机的shell,干你想干的任何事情

<code># docker run -i -t centos /bin/bash</code>

6、官方的这个centos镜像非常小,不到100M,如果需要配置一个复杂的环境,请直接yum解决。

docker 也提供了在线搜索镜像模板功能,类似与puppet在线安装模板(步骤1)

<code># docker search ubuntu</code>

<code># docker search centos</code>

<code># docker search debian</code>

总结

docker 是一个年轻的容器项目,跟FreeBSD 的jail 相比,还不怎么成熟,但是容器技术仍然代表着一个先进的虚拟化方向。

本文转自 紫色葡萄 51CTO博客,原文链接:http://blog.51cto.com/purplegrape/1340541,如需转载请自行联系原作者