从代码到上线, 云端Docker化持续交付实践

简介: 2016云栖大会·北京峰会于8月9号在国家会议中心拉开帷幕,在云栖社区开发者技术专场中,来自阿里云技术专家罗晶(瑶靖)为在场的听众带来《从代码到上线, 云端Docker化持续交付实践》精彩分享。

2016云栖大会·北京峰会于89号在国家会议中心拉开帷幕,在云栖社区开发者技术专场中,来自阿里云技术专家罗晶(瑶靖)为在场的听众带来《从代码到上线, 云端Docker化持续交付实践》精彩分享。

关于分享者:

罗晶,花名瑶靖。在加入阿里云之前,先后在支付宝平台数据技术事业群、百度基础架构部任职。现主要负责阿里云容器服务产品的集群管理系统的研发,从事容器的持续交付、持续集成的方案设计与实现。

演讲内容架构

  • 大话持续交付
  • 持续交付的前世
  • 容器化DevOps
  • 持续交付的今生

演讲主要内容

持续集成指的是,频繁地(一天多次)将代码集成到主干。持续集成的目的,就是让产品可以快速迭代,同时还能保持高质量。它的核心措施是,代码集成到主干之前,必须通过自动化测试。只要有一个测试用例失败,就不能集成。

fe28e6ce50c3caaa19c0bb11e67f8229ddaf8599

持续交付(Continuous delivery)指的是,频繁地将软件的新版本,交付给质量团队或者用户,以供评审。如果评审通过,代码就进入生产阶段。

持续交付可以看作持续集成的下一步。它强调的是,不管怎么更新,软件是随时随地可以交付的。

2e886256563efba6023ff93cd0c72d592c68b03a

持续集成和持续交付保证了软件的持续运行和有效反馈。

c0b4ba590916ac79010f397a9ae7a0e98d09581b

不同环境,不同交付运维方式。即便按照流程去做持续交付,系统地搭建出来整个持续集成的系统环境,一样会遇到七七八八这样的问题。就算是同一种语言,每一个开发者所依赖语言环境、依赖的包不一样,就会导致有非常多的编译环境,维护起来就很困难。

 

 

e6922161c4b138b1878700b0832498f2c16141b5

传统持续交付问题的根源在于:

  • 开发者交付的只有代码以及代码的依赖;
  • 运维者需要除了代码之外的运行环境,以及运行环境之间的依赖。

f8c5be1d5944ef54fdad2b1ffac42ccf2806c331

 

交付方式的变革

Docker的出现改变软件交付的方式。经济学家说过:没有集装箱,不可能有全球化。Docker就像把一堆零散的代码和我要的所有东西装在集装箱里,真正去交付给运维时,相当于把这个集装箱运行起来。它包含所有的环境依赖,所以在任何地方运行集装箱所达到的结果都是一样的。因为达到了环境一致性。

 

baa724109956da55e0d168ff8e700bf9687db10c

Docker之所以这么火,是由于它的敏捷、可移植、可控的特性决定的。敏捷意味着Docker可以秒级应用启动、轻量级隔离、细粒度资源控制、低性能损耗;可移植代表着Docker的环境无关的交付、部署方式、可用于软件生命周期中不同运行环境;可控表示容器级别的资源隔离和流控。

4217fb3639b65c0ef27b44fe105bd72d4a489b21

Docker Compose是Docker推出来的一个对多容器的编排技术,简单好用,便于开发。使用Docker Compose,可以一键构建本地开发环境,在团队中可以共享一份配置文件。它的优点是:

  • 简单好用,便于开发
  • 本地环境沙箱
  • UT环境
  • 编排容器、存储和网络

当然,它也存在不足:面向开发和部署,不支持自动化运维。

73fe4e39b9cc3f3c43a987284ede8625bd4e571d

Docker Swarm把一组Docker引擎抽象成一个Docker引擎,以前所有在单机上对一个Docker引擎的工作,都可以透明的变成对一组Docker集群上的节点的操作。Docker Swarm它的优点是:

  • 支持标准的 Docker API;
  • 灵活、可扩展、可插拔的容器调度。

当然,它也存在不足:面向容器、缺少服务生命周期支持。

5e6394f454f65ff30b46c5bf44af622b87317f60

容器服务上有三个层面的概念:

  • 资源层面——集群,节点。
  • 内容层面——Compose模板,镜像。
  • 应用层面——应用,服务,容器。

a0d0f745f524539b958a0bca6534387363f150da

容器化DevOps,可以实现:

  • 开发环境到生产环境的一致
  • 可编程基础设施
  • Infrastructure as Code
  • 不可变基础架构
  • Immutable infrastructure
  • 全流程工具化、自动化、持续交付
  • 降低试错成本,鼓励快速迭代

84a28162be9623676c9bc57cd7b1b5677f0f0355

简单的容器化持续交付流程如下图所示:

59a59604013de090dffdd35c3ba53e5018366605

复杂的容器化持续交付流程:开发人员在除了代码 、Config、Test脚本还要写Dockerfile。把这些代码传(Push)到代码仓库,有一个CI service通过代码仓库hook告诉你代码仓库有一个新的提交。把代码拉下来复制,进行两件事情 : Build和UT。在build的过程中,会从Docker Registry上面去拉下来( Pull )依赖的image,当build通过了之后会push image到这个Docker Registry单位里面去。然后CI 会有一个hook去通知CD,deploy Service根据Docker和image描述以及compose描述,把image部署到预发、测试或者生产环境。

9614c1a78d88bac46f2314532a9bbd1c215e1a09

持续交付“最后一公里”

发布时持续交付的“最后一公里”,常见的发布策略有蓝绿发布、金丝雀发布(灰度发布)、ABTest,在国内的开发者中,对这几个概念有独立的理解。

Rolling Update

  • 依次停止老容器,启动新容器
  • 整个过程自动化,无需用户手动操作
  • 适合于多副本的应用发布

fdcc58cfea7d3d3e78a6a50380bcd75374c92839

蓝绿发布(热部署)

  • 不会停止老容器,为新服务启动新容器
  • 需要用户设置路由权重,实现不同版本应用的上线、下线
  • 适合于版本的快速发布,不会停机影响用户

78d31cfb1f3fd783747026d03cf2a6ec079846d2

金丝雀发布(灰度)

  • 不会停止老容器,为新服务启动新容器
  • 需要用户设置路由权重,实现不同版本应用的共存
  • 支持A/B测试,适合多方案选择

7f144a8087c065f73a776026c6bb648031764ea2

相关文章
|
3月前
|
Kubernetes Docker Python
Docker 与 Kubernetes 容器化部署核心技术及企业级应用实践全方案解析
本文详解Docker与Kubernetes容器化技术,涵盖概念原理、环境搭建、镜像构建、应用部署及监控扩展,助你掌握企业级容器化方案,提升应用开发与运维效率。
756 108
|
2月前
|
弹性计算 关系型数据库 微服务
基于 Docker 与 Kubernetes(K3s)的微服务:阿里云生产环境扩容实践
在微服务架构中,如何实现“稳定扩容”与“成本可控”是企业面临的核心挑战。本文结合 Python FastAPI 微服务实战,详解如何基于阿里云基础设施,利用 Docker 封装服务、K3s 实现容器编排,构建生产级微服务架构。内容涵盖容器构建、集群部署、自动扩缩容、可观测性等关键环节,适配阿里云资源特性与服务生态,助力企业打造低成本、高可靠、易扩展的微服务解决方案。
1582 9
|
2月前
|
人工智能 前端开发 Docker
从本地到云端:用 Docker Compose 与 Offload 构建可扩展 AI 智能体
在 AI 智能体开发中,开发者常面临本地调试与云端部署的矛盾。本文介绍如何通过 Docker Compose 与 Docker Offload 解决这一难题,实现从本地快速迭代到云端高效扩容的全流程。内容涵盖多服务协同、容器化配置、GPU 支持及实战案例,助你构建高效、一致的 AI 智能体开发环境。
323 1
从本地到云端:用 Docker Compose 与 Offload 构建可扩展 AI 智能体
|
2月前
|
缓存 安全 Linux
优化Docker镜像大小的多阶段构建实践
优化Docker镜像大小的多阶段构建实践
263 99
|
4月前
|
缓存 Java Docker
如何对应用代码进行优化以提高在Docker容器中的性能?
如何对应用代码进行优化以提高在Docker容器中的性能?
281 1
|
8月前
|
Ubuntu 关系型数据库 MySQL
容器技术实践:在Ubuntu上使用Docker安装MySQL的步骤。
通过以上的操作,你已经步入了Docker和MySQL的世界,享受了容器技术给你带来的便利。这个旅程中你可能会遇到各种挑战,但是只要你沿着我们划定的路线行进,你就一定可以达到目的地。这就是Ubuntu、Docker和MySQL的灵魂所在,它们为你开辟了一条通往新探索的道路,带你亲身感受到了技术的力量。欢迎在Ubuntu的广阔大海中探索,用Docker技术引领你的航行,随时准备感受新技术带来的震撼和乐趣。
357 16
|
12月前
|
Kubernetes Linux Docker
容器化技术Docker入门与实践
容器化技术Docker入门与实践
189 20
|
12月前
|
关系型数据库 MySQL Java
【Docker最新版教程】一文带你快速入门Docker常见用法,实现容器编排和自动化部署上线项目
Docker快速入门到项目部署,MySQL部署+Nginx部署+docker自定义镜像+docker网络+DockerCompose项目实战一文搞定!
1969 10
|
12月前
|
安全 持续交付 Docker
深入理解并实践容器化技术——Docker 深度解析
深入理解并实践容器化技术——Docker 深度解析
473 2
|
Prometheus 监控 持续交付
深入理解Docker容器化技术:从基础到实践
深入理解Docker容器化技术:从基础到实践