Docker:具备一致性的自动化软件部署
来源:互联网 发布:海马玩mac版 编辑:程序博客网 时间:2024/06/07 17:39
Docker使用标准化容器的概念,能够容纳软件组件及其依赖关系——二进制文件、类库、配置文件、脚本、Virtualenv、jar包、gem包、原始码等——而且可以在任何支持cgroups的64位(针对x64)Linux内核上运行。这样的容器可以部署在笔记本、分布式基础架构、云端或是其他地方,其对环境的保留适用于广泛的用途:持续部署、Web部署、数据库群集、SOA等等,对此,Mike Kavis在他的博客中这样描述:
作为应用开发者,与我相关的用例是使用Docker以简化持续交付过程。在我职业生涯中工作过的每个地方,在那些从大型机到客户端再到云端的岁月里,让不同的环境保持同步并成功测试应用简直是个噩梦。无论我们的流程有多好或者有多糟,在“Dev-QA-Stage-Prod(开发-质量保证-过渡-生产)”的迁移过程中的各个阶段里,代码从来就没有处于相同的环境。最后的结果就是,发布的产品总是出现质量问题。“它在测试阶段是好的”是仅次于“支票已经寄出了”(译者注:the check is in the mail为美国俚语,意指某件应该发生某事但实际情况却与之不符,最早是债务人用于缓和债权人的愤怒情绪的一种借口)的推脱借口。
在持续交付(CD)过程中,整个环境随着代码一起在“Dev-QA-Stage-Prod”的不同阶段间迁移。配置问题,系统环境不同的问题,借口都将不复存在。在CD过程中,如果代码在产品阶段出问题,那么在测试阶段也一样有问题。使用Docker的过程中,我知道能够通过编写脚本实现CD流程的自动化。我还知道,因为无需处理所有的安装和配置问题,随着创建新环境的速度加快,产品进入市场的速度也得到了提升。
dotCloud的CEO Solomon Hykes在PyCon上演示了Docker,宣称它是可重复的轻量级虚拟化解决方案,因为“它在进程层面是独立的,而且拥有自己的文件系统”。其API允许系统管理员对容器进行一系列操作:开始、停止、复制、等待、提交、关联标准流、列出文件系统变更等等。
Docker的主要特性如下:
- 文件系统隔离:每个进程容器运行在完全独立的根文件系统里。
- 资源隔离:可以使用cgroup为每个进程容器分配不同的系统资源,例如CPU和内存。
- 网络隔离:每个进程容器运行在自己的网络命名空间里,拥有自己的虚拟接口和IP地址。
- 写时复制:采用写时复制方式创建根文件系统,这让部署变得极其快捷,并且节省内存和硬盘空间。
- 日志记录:Docker将会收集和记录每个进程容器的标准流(stdout/stderr/stdin),用于实时检索或批量检索。
- 变更管理:容器文件系统的变更可以提交到新的映像中,并可重复使用以创建更多的容器。无需使用模板或手动配置。
- 交互式Shell:Docker可以分配一个虚拟终端并关联到任何容器的标准输入上,例如运行一个一次性交互shell。
目前,Docker已在Ubuntu 12.04和12.10测试过,但dotCloud表示它应该能够在内核版本号2.6.24或更高的Linux上运行。它还可以在Windows或Mac OS X中,使用Vagrant在VirtualBox的虚拟机里安装。Docker是用Go语言编写的,并使用了Linux的cgroup、namespacing、支持写时复制特性的AUFS文件系统以及LXC脚本。
- Docker:具备一致性的自动化软件部署
- Docker:具备一致性的自动化软件部署
- Docker与自动化部署
- docker自动化部署实战
- Docker自动化部署方案
- DevOps之Docker自动化部署
- jenkins加docker自动化部署
- 软件自动化部署脚本
- 58赶集基于 Docker 的自动化部署实践
- docker+selenium web自动化测试环境的部署
- ANT实现自动化软件部署
- 自动化部署软件安装脚本
- Linux软件自动化部署脚本
- centos+Docker +Jenkins 自动化部署配置
- Git+Docker+Jenkins+React App自动化部署
- docker安装jenkins搭建自动化部署
- jenkins和docker实现自动化构建部署
- 在搭建基于jenkins+maven+git+docker的全自动化部署时遇到的问题
- 软件测试基础
- Linux Commands for Beginners--Finding Files
- 《火球——UML大战需求分析》(第1章 大话UML)——1.5 小结和练习
- 使用html直接给swf添加链接
- shell脚本处理字符串常用方法
- Docker:具备一致性的自动化软件部署
- linux 下开放指定端口
- 代码走查规范表
- STL之缓冲区迭代器
- Matlab如何找出两个矩阵中相同的元素
- 调整viewState的位置,有助于SEO
- 读写SD卡上的文件
- k-means
- 聚集索引和非聚集索引