场景一:节省项目环境部署时间
1.单项目打包 每次部署项目到测试、生产等环境,都要部署一大堆依赖的软件、工具,而且部署期间出现问题几率很大,不经意就花费了很长时间。 |
Docker 主要理念就是环境打包部署,可在任意 Docker Engine 运行。前期我们只需要将每个项目环境打包到镜像,push 到镜像仓库,当有需要部署这个项目时,直接 pull 镜像启动容器,这个项目就可以访问了!一次构建多次部署,一劳永逸。 3.新开源技术试用 有时,我们想调研一些开源项目,我们可以直接从公共镜像仓库 pull 项目官方做好镜像启动容器即可。 |
场景二:环境一致性 开发工程师在 Windows 系统上开发项目,测试、生产环境操作系统都是 Linux 系统,这就产生了环境不一致的情况:项目在开发电脑本地运行没问题,到了测试或生产环境就运行不起来,解决这问题最好方式就是这三处环境保持一致。软件版本、操作系统、物理机、云主机......试想下,能做到吗? |
Docker 将项目环境打包成镜像,可以在任何 Docker Engine 上浪。此时 Docker 就是我们这些项目的基石,Docker 可移植性,保持运行状态一致性,可想而知,是否更容易解决问题呢? 场景三:持续集成 一个项目版本快速迭代的测试场景,需要一个合理的 CI(持续集成)/CD(持续部署)环境支撑。CI/CD 是一个周期性自动化项目测试流程,包括构建、部署、测试、发布等工 |
作,很少需要人工干预。
项目测试流程大致如下图:
Docker 结合 Jenkins 构建持续集成环境大致如下图: |
Docker 在上面这个图的作用是项目镜像构建和快速部署,打通测试环境与生产环境,高度保持多个环境之间一致性。 |
场景四:微服务 微服务是近几年来 IT 圈内谈论比较多的一个名词,意义也很简单:尽可能细粒度拆分业务程序架构,由多个独立服务组成业务系统。 场景五:弹性伸缩 |
说到弹性伸缩,通常是集群模式下存在。像 AWS AutoScaling,可以自定义资源阈值,SLB 自动添加 EC2 云主机,应对业务访问量突发情况。 由于 Docker 容器快速启动特性,可以很快速的启动几十个、上百个容器来提供更多并发和资源利用率(如果宿主机资源不够,还需要加主机到集群中)。 |
小结: 根据上述应用场景总结下 Docker 特点:开箱即用,快速部署,可移植性强,环境隔离等。 以上场景特点相互相应,只有一个共同目标:简化部署流程,提高生产力!
|
Docker 技术课程地址:http://opsdev.ke.qq.com |
文章来源:http://lizhenliang.blog.51cto.com/7876557/1978081 |