[译] 第二十一天: Docker - 缺失的指南

前言

几个月前,红帽宣布了和dotCloud关于Docker技术的合作关系。当时没有时间去了解Docker, 趁现在30天挑战,我决定来看看Docker究竟是什么。本文不讨论以后OpenShift怎样用Docker, 你可以参考Mike McGrath关于OpenShift和Docker的技术思考,或者从stackoverflow问题理解怎样将Docker比作OpenShift.

Docker是什么?

Docker为应用程序提供了一层壳(或者容器),由dotCloud作为非主流项目启动,年初就开源了。它受到了广泛关注,以致有消息称dotCloud改名为Docker Inc. 最开始由Go语言编写,作为LXC(LinuX Containers)的管道,使开发者能采用高级概念。 

Docker扩展Linux Containers, 或者LXC, 在高级API提供独立运行的轻量虚拟解决方案。它利用LXC, cgroups,和Linux kernel自身,和传统虚拟机不同,Docker容器没有一个独立的操作系统,替代的是依赖底层架构提供的操作系统功能。Stackoverflow对LXC上Docker提供的所有功能的给出了详细解释。 

Docker作为便捷式容器引擎,将所有依赖打包到虚拟容器中,可以在任何Linux服务器上运行。这使得程序不管在哪运行,不论什么准备,公共云,私有云,裸机等等环境下,都能灵活便捷的使用。 

Docker的组成:

  1. Docker服务器进程,负责管理所有容器。
  2. Docker命令行终端,控制服务器进程。
  3. Docker镜像仓库,存放docker镜像,地址 https://index.docker.io/ 

我为什么关注Docker?

Docker很有用因为从一个机器向另一个转移代码常常很困难,它尝试将软件转移过程更稳定和自动。Docker容器对所有运行Docker的操作系统都很便捷。更多了解Fedora 项目是怎样使用Docker的。 

我已经使用VMs了

目前稳定转移程序唯一正确的选择是虚拟机(VMs), 虚拟机现在很普遍,当时他们很低端,同时也要提供完整的操作系统。虚拟机的问题是过分转移,他们打包了大量不是必须的信息如硬件驱动,虚拟处理器,网络接口。而且也要花很长时间来Boot, 占用大量内存和CPU. 

相反,Docker很轻量级,几乎相当于启动一个常规流程,不仅仅是运行容器很快,构建镜像和文件系统快照也很快,可以在像EC2或者RackSpace VMs的虚拟环境中工作。实际上,在Mac和Windows上更好的使用Docker的方式是用Vagrant. Docker的目的是像VM一样工作,不过更快的启动,占用更少的资源。 

类似Vagrant吗?

我的另一个疑惑是,我下一个项目要创建sandboxed环境该用Vagrant还是Docker呢。答案是一样的。 

Docker在系统开销方面比Vagrant更优,Vagrant提供的环境任然是虚拟机,依赖Virtual Box. 详情请参考stackoverflow给出的解释。 

Oh No! 另一个程序打包系统

我第一次看到Docker打包程序是困惑了,我们为什么需要另一个打包系统?我已经把我的Java程序打包成JAR或者WAR了。更多了解后我知道了Docker程序打包的意义。Docker处于虚拟机和你的程序包如WAR或者JAR之间,虚拟机一方面是很重量级的,它不仅仅是打包,另一方面,程序代码是很轻量的,没有转移足够的信息去稳定运行程序。Docker满足了两方面。 

在Docker里,程序打包意味着包含程序代码和必需的部署环境。例如,Java我们一般打包web程序为WAR文件,WAR包是最低要求的包只有程序代码,但是程序需要依赖部署环境来有效运行,可能出现不同的部署环境,开发时用的Java 7但是部署环境是OpenJDK Java 6或者在Mac上开发的但是部署在RHEL,也可能发生在有些系统库的不同导致开发和部署不同的结果。Docker帮助减少了这些问题,不仅打包程序还有依赖。 

开始Docker

参照这篇博客的指导在Fedora机器上安装Docker.

$ vagrant up

$ vagrant ssh
View Code

然后安装Docker fedora镜像

$ sudo docker pull mattdm/fedora
View Code

以上命令会从 https://index.docker.io/ 下载Docker fedora镜像。 

安装之后,可以用以下命令列出所有镜像。

$ sudo docker images

 

REPOSITORY                     TAG                 IMAGE ID            CREATED             SIZE

shekhargulati/node_image_007   latest              e12b3054d981        50 minutes ago      470.3 MB (virtual 601.8 MB)

 

mattdm/fedora                         12.04               8dbd9e392a96        7 months ago        131.5 MB (virtual 131.5 MB)
View Code

列出的第一个是我已经创建好的,打包了NodeJS和Express Framework, 第二个是docker fedora备份。 

现在在docker容器里运行shell.

$ sudo docker run -t -i -p 3000 mattdm/fedora /bin/bash
View Code

运行后,我们就在Docker容器里,可以用 ls命令列出所有文件。 

现在创建以下目录结构 /home/shekhar/dev

$ mkdir -p home/shekhar/dev

$ cd home/shekhar/dev
View Code

安装NodeJS, 运行以下名在Fedora Docker镜像上安装Node.

$ sudo yum install npm
View Code

以上命令会在Fedora Docker镜像上安装Nodejs. 

接下来安装Express Framework.

$ npm install express -g
View Code

安装之后新建一个程序运行。

$ express myapp

$ cd myapp

$ npm install

$ node app.js
View Code

以上命令会启动NodeJS Express程序,端口3000. 

另外打开一个命令窗口,列出所有Docker进程。

$ sudo docker ps

CONTAINER ID        IMAGE                                 COMMAND             CREATED             STATUS              PORTS                     NAMES

4a5715a915e5        mattdm/fedora   /bin/bash           5 minutes ago       Up 5 minutes        0.0.0.0:49157->3000/tcp   red_duck
View Code

你会注意到端口3000绑定到主机端口49157, 可以通过curl测试。

$ curl 0.0.0.0:49157

<!DOCTYPE html><html><head><title>Express</title><link rel="stylesheet" href="/stylesheets/style.css"></head><body><h1>Express</h1><p>Welcome to Express</p></body></html>
View Code

现在执行镜像推送到Docker镜像注册表,在这之前,你需要先在Docker registry注册。https://index.docker.io/account/signup/

$ sudo docker commit 4a5715a915e5 shekhargulati/node_image_007

$ sudo docker push shekhargulati/node_image_007
View Code

用你自己的用户名和镜像名。 

就这样,我的第一个镜像完成,上传到Docker registry  https://index.docker.io/u/shekhargulati/node_image_007/

可以用pull命令从registry获取镜像。

$ docker pull shekhargulati/node_image_007
View Code

这就是今天的内容,继续给反馈吧。 

原文:https://www.openshift.com/blogs/day-21-docker-the-missing-tutorial

posted on 2014-01-08 18:17  百花宫  阅读(1853)  评论(1编辑  收藏  举报