Docker:具备一致性的自动化软件部署
来源:互联网 发布:energycut软件 编辑:程序博客网 时间:2024/06/05 02:34
PaaS供应商dotCloud开源了自有平台上的关键组件Docker。Docker是一种增加了高级API的LinuX Container(LXC)技术,提供了能够独立运行Unix进程的轻量级虚拟化解决方案。它提供了一种在安全、可重复的环境中自动部署软件的方式。
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: Automated and Consistent Software Deployments
转自:http://www.infoq.com/cn/news/2013/04/Docker
- 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的全自动化部署时遇到的问题
- java中equal()方法和==的区别
- C# Socket异步通信
- 解决linux的-bash: ./xx: Permission denied
- setsockopt()改善程序的健壮性
- 解决下载文件在IE,ff文件名的乱码问题
- Docker:具备一致性的自动化软件部署
- 内存溢出工具
- MySql笔记
- 云计算实战之url 关键词及分类管理
- jquery中each用法
- 重新配置与卸载 11gR2 Grid Infrastructure
- webview长按弹出菜单
- 使用sshfs来让sublime打开远程目录
- QT中的model/view