• [译] 第二十一天: 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

  • 相关阅读:
    Redis存储对象(序列化和反序列化)
    JAVA中关于set()和get()方法的理解以及使用
    5W1H分析法
    Spring AOP的理解(通俗易懂)。
    Notepad++ 使用步骤,熟练掌握notepad++的使用技巧,无疑会大大提升专业技能。以及快捷键操作
    Int,String,Integer,double之间的类型的相互转换
    Ajax局部刷新和全局刷新的区别
    GET和POST都是什么时候用?
    ajax为什么需要json格式响应数据?
    final fially finalize区别
  • 原文地址:https://www.cnblogs.com/endless-on/p/3511159.html
Copyright © 2020-2023  润新知