持续交付(第五章)—部署流水线解析

在上一章中,学到了关于测试的一些策略实现,作者从两个维度对测试进行划分,一个是业务导向,还是技术导向,另一个维度是为了支持开发过程,还是为了对项目进行评价。在这一章中,作者向我们介绍了部署流水线。

持续集成

什么是部署流水线

从某种抽象层次上讲,部署流水线是指软件从版本控制库到用户手中这一过程的自动化表现形式。部署流水线是对软件从设计,开发,构建,测试等过程的建模,在持续集成和发布管理工具上,它体现为支持查看并控制流程,包括每次变更从被提交到版本库控制开始,直至通过各类测试和部署,再到发布给用户的过程。

部署流水线的相关实践

  • 只生成一次二进制包
  • 对不同环境采用同一部署方式
  • 对部署进行冒烟测试
  • 向生产环境的副本中部署
  • 每次变更都要立即在流水线中传递
  • 只要有环节失败,就停止整个流水线

提交阶段

我们不想在那些明显有问题的版本上花费时间和精力,所以当开发人员提交变更到版本控制系统后,我们希望尽快地评估一下这个版本,让开发人员快速得到反馈,所以我们需要践行提交阶段的最佳实践,开发人员需要一直等到部署流水线的提交阶段成功完成,如果失败了,开发人员要么快速修复问题,要么将提交的代码回滚。

部署流水线的测试

部署流水线中很大一部分就是测试,跑各种各样的测试,快速获取反馈进行修改。全面的提交测试套件对于发现许多错误来说,是非常优秀的试金石,在这个试金石中,我们的测试有,单元测试,集成测试,组件测试,配置测试,冒烟测试,手工测试,探索性测试等等,从各个方面帮助我们去尽在发现在项目中潜在的问题。

实现一个部署流水线

无论是从零创建一个项目,还是想为已有的系统创建一个自动化的流水线,通常都应该使用增量式的方法来实现部署流程。建立一个完整的流水线的策略,步骤如下:

  • 对价值流的建模,并创建一个可工作的简单框架
  • 将构建和部署自动化
  • 将单元测试和代码分析自动化
  • 将验收测试自动化
  • 将发布自动化

总结

我的收获

  • 部署流水线的前提就是项目自动化,测试的完备性,反馈的及时性,以及团队成员对于持续交付的相关实践。
  • 增量式开发

我的疑惑

  • 价值流建模的可行性怎么样?团队可以按照原有的日期按时完成么
  • 冒烟测试是测试哪方面的?
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,293评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,604评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,958评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,729评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,719评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,630评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,000评论 3 397
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,665评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,909评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,646评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,726评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,400评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,986评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,959评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,996评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,481评论 2 342

推荐阅读更多精彩内容

  • 部署流水线 出现原因在软件的发布过程中,很多浪费来自于测试和运维环节。解决方案就是采取一种更完善的端到端的方法来交...
    落花的季节阅读 1,356评论 0 0
  • 一 什么是部署流水线 部署流水线是指软件从版本控制库到用户手中这一过程的自动化表现形式。我们知道软件的每一次变更都...
    司鑫阅读 514评论 0 1
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,594评论 18 139
  • 基本的部署流水线就是从提交开始逐步通过每个测试阶段的自动化的过程。越往前的阶段有更快的反应速度,越往后走,信心不断...
    大饭团子阅读 1,441评论 0 1
  • 今天,带我学车的朋友说,很久没见你了。立夏了,准备来游泳吧。不是一直想学么?去年赶上了尾巴,今年重新开始吧。 对于...
    格格blue0229阅读 248评论 2 1