Docker 培训.ppt
Docker 内部培训涂飞平2014-05-06一、什么是Docker?Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPhone 的 app)。几乎没有性能开销,可以很容易地在机器和数据中心中运行。最重要的是,他们不依赖于任何语言、框架或包装系统。(摘自百度)Docker 是 PaaS 提供商 dotCloud 开源的一个基于 LXC 的高级容器引擎,源代码托管在 Github 上,基于go语言更多信息请参考http:/ install lxc-docker就可以安装docker了,从名字可以看出docker与lxc的关系,至于lxc是什么,可以自行Google,lxc是docker的底层实现,是一种linux的内核虚拟化的工具集合安装完毕后,使用命令 docker-version查看版本并确定是否安装成功 四、Docker的基本元素Image 提供一个快速部署的模板,这是与lxc最大的区别,可以基于一个Image快速部署多个相同的容器,docker images命令可以查看目前系统有哪些镜像 Container容器,可以简单认为是虚拟机了(虽然不准确),它是我们工作实体,每个Container相当于一个完整的Linux系统,docker ps命令可以查看目前系统有哪些容器五、如何创建/获得Docker Image5.1、通过网络获取可以到http:/index.docker.io网站查找是否有自己需要的docker image,如果有合适的,直接使用 docker pull命令就可以获取到。5.2、自己构建如果没有合适的,这个时候我们可以通过编写Dockerfile文件,然后通过 docker build命令来创建自己image。六、Dockerfile简介详细请参考http:/docs.docker.io/reference/builder/基本指令(比较重要的指令)FROM RUN ADD CMD/ENTRYPOINT USER EXPOSE样例生成Imagedocker build-t msgserver.#IRP develope base imageFROM irp5-base:latestMAINTAINER Sunny#install vimRUN apt-get install-y vimUSER rootEXPOSE 8080EXPOSE 5432EXPOSE 22ENTRYPOINT/usr/local/run.py七、生成,使用Container如果把Image比作Java中的类(Class),那Container就是Java中的对象(Object)了,真正做实事的就是Container在Docker中,只要使用docker run运行一个image,就会生成一个container(没错,每次运行都生成一个新的container),所以一般都是运行一次后,记录ContainerID,然后在需要开始或者停止的时候使用docker start/stop命令来启动或者停止示例docker run-d-p 11211:11211-p 23044:22 memcacheddocker ps可以查看已经启动的container信息八、现状和建议公司内部的服务都已经部署好的,都已经写好脚本了,所有的container都有静态映射ssh端口,可以进入后进行细微的配置调整(docker在公司内部目前主要作为paas平台在应用)如果构建新的image和container,需要系统地学习docker的使用建议学习docker前,先学习lxc的使用和概念,有时间,可以参考docker的源代码,能更深入了解docker是怎样整合其他工具和技术的谢谢大家谢谢大家