DevOps - 维基百科,自由的百科全书

文章推薦指數: 80 %
投票人數:10人

DevOps(Development和Operations的组合詞)是一种重视「软件开发人员(Dev)」和「IT运维技术人员(Ops)」之间沟通合作的文化、运动或慣例。

通过自动化「软件交付」 ... DevOps 维基百科,自由的百科全书 跳到导航 跳到搜索 此條目需要补充更多来源。

(2014年6月12日)请协助補充多方面可靠来源以改善这篇条目,无法查证的内容可能會因為异议提出而移除。

致使用者:请搜索一下条目的标题(来源搜索:"DevOps"—网页、新闻、书籍、学术、图像),以检查网络上是否存在该主题的更多可靠来源(判定指引)。

软件开发 核心行动 过程 需求 设计 工程 构造(英语:Softwareconstruction) 测试 调试 部署 維護 范式与模式 原型设计(英语:Softwareprototyping) 净室(英语:Cleanroomsoftwareengineering) 增量建模(英语:Incrementalbuildmodel) 瀑布模型 敏捷软件开发 螺旋模型 方法论与框架 快速應用程式開發 DevOps 极限编程 团队软件流程(英语:Teamsoftwareprocess) 個人軟體程序 动态系统开发方法(英语:Dynamicsystemsdevelopmentmethod) MSF(英语:MicrosoftSolutionsFramework) Scrum 看板 V模型 FDD(英语:Feature-drivendevelopment) MDD 迭代式开发 精實开发 统一流程(英语:UnifiedProcess) 支持行为 配置管理 文档 质量保证 项目管理 用户体验 实践 ATDD(英语:Acceptancetest–drivendevelopment) 行为驱动开发 持續整合 持續交付 領域驅動設計 结对编程 站会 测试驱动开发 工具 編譯器 调试工具 性能分析 GUI设计器(英语:Graphicaluserinterfacebuilder) 建模(英语:UMLtools) 集成开发环境 組建自動化 发布自动化(英语:Applicationreleaseautomation) 测试 标准与知识体系 能力成熟度模型集成 IEEE标准 ISO9001 ISO/IEC标准(英语:ISO/IECJTC1/SC7) SWEBOK(英语:SWEBOK) 项目管理知识体系 BABOK(英语:BABOK) 查论编 DevOps(Development和Operations的组合詞)是一种重视「软件开发人员(Dev)」和「IT运维技术人员(Ops)」之间沟通合作的文化、运动或慣例。

通过自动化「软件交付」和「架构变更」的流程,来使得构建、测试、发布软件能够更加地快捷、频繁和可靠。

[1][2][3][4] 可以把DevOps看作开发(软件工程)、技术运营和质量保障(QA)三者的交集。

传统的软件组织将开发、IT运维和质量保障设为各自分离的部门,在这种环境下如何采用新的开发方法(例如敏捷软件开发),是一个重要的课题。

按照从前的工作方式,开发和部署,不需要IT支持或者QA深入的跨部门的支持;而现在却需要极其紧密的多部门协作。

而DevOps考虑的还不止是软件部署,它是一套针对这几个部门间沟通与协作问题的流程和方法。

[5] 需要频繁交付的企业可能更需要对DevOps有一个大致的了解。

Flickr发展了自己的DevOps能力,使之能够支撑业务部门“每天部署10次”的要求[6]──如果一个组织要生产面向多种用户、具备多样功能的应用程序,其部署周期必然会很短。

这种能力也被称为持续部署[7],并且经常与精益创业方法联系起来。

[8]从2009年起,相关的工作组、专业组织和博客快速涌现。

[9][10][11][12] DevOps的引入能对产品交付、测试、功能开发和维护(包括──曾经罕见但如今已屡见不鲜的──“热补丁”)起到意义深远的影响。

在缺乏DevOps能力的组织中,开发与运营之间存在着信息“鸿沟”──例如运营人员要求更好的可靠性和安全性,开发人员则希望基础设施响应更快,而业务用户的需求则是更快地将更多的特性发布给最终用户使用。

这种信息鸿沟就是最常出问题的地方。

以下几方面因素可能促使一个组织引入DevOps: 使用敏捷或其他软件开发过程与方法 业务负责人要求加快产品交付的速率 虚拟化[13]和云计算基础设施(可能来自内部或外部供应商)日益普遍 数据中心自动化技术[14]和配置管理工具的普及 有一种观点认为,目前占主导地位的“传统”美国式管理风格(“斯隆模型vs丰田(日语:豊田英二)模型”)[15]会导致“烟囱式自动化”,从而造成开发与运维之间的鸿沟,因此需要DevOps能力来克服由此引发的问题。

DevOps经常被描述为“开发团队与运维团队之间更具协作性、更高效的关系”。

由于团队间协作关系的改善,整个组织的效率因此得到提升,伴随频繁变化而来的生产环境的风险也能得到降低。

目录 1对应用程序发布的影响 2现状 3诉求 4发布协调人 5参见 6参考文献 7外部链接 对应用程序发布的影响[编辑] 在很多企业中,应用程序发布是一项涉及多个团队、压力很大、风险很高的活动。

然而在具备DevOps能力的组织中,应用程序发布的风险很低,原因如下: 与传统开发方法那种大规模的、不频繁的发布(通常以“季度”或“年”为单位)相比,敏捷方法大大提升了发布频率(通常以“天”或“周”为单位) 减少变更范围 与传统的瀑布式开发模型相比,采用敏捷或迭代式开发意味着更频繁的发布、每次发布包含的变化更少。

由于部署经常进行,因此每次部署不会对生产系统造成巨大影响,应用程序会以平滑的速率逐渐生长。

加强发布协调 靠强有力的发布协调人来弥合开发与运维之间的技能鸿沟和沟通鸿沟;采用电子数据表、电话会议、即时消息、企业门户(wiki、sharepoint)等协作工具来确保所有相关人员理解变更的内容并全力合作。

自动化 强大的部署自动化手段确保部署任务的可重复性、减少部署出错的可能性。

现状[编辑] 很多组织将开发和系统管理划分成不同的部门。

开发部门的驱动力通常是“频繁交付新特性”,而运维部门则更关注IT服务的可靠性和IT成本投入的效率。

两者目标的不匹配,就在开发与运维部门之间造成了鸿沟,从而减慢了IT交付业务价值的速度。

开发人员经常不考虑自己写的代码会对运维造成什么影响。

他们在交付代码之前,并不邀请运维人员参与架构决策或代码评审。

开发人员对配置或环境进行修改之后,经常没有及时与运维人员沟通,导致新的代码不能运行。

开发人员在自己的机器上手工修改配置,而没有记录所有需要的步骤。

想找到必要的配置参数,通常需要尝试很多不同的参数;在得到一个可工作的状态后,往往很难识别出通过哪些最小步骤就能到达该状态。

开发人员倾向于使用有利于快速开发的工具:对代码修改更快的反馈,更低的内存消耗,等等。

这样的工具集与运维人员面对的目标运行时环境非常不同:后者对稳定性和性能的要求远胜于灵活性。

由于开发人员平时使用桌面电脑,他们倾向于使用为桌面用户优化的操作系统。

生产环境的运行时系统通常都运行服务器操作系统上。

在开发过程中,系统在开发者的本地机器上运行。

在运维过程中,系统经常分布在多台服务器上,例如web服务器、应用服务器、数据库服务器等等。

开发是由功能性需求(通常与业务需求直接相关)驱动的。

运维是由非功能性需求(例如可获得性、可靠性、性能等)驱动的。

运维人员希望尽量避免修改功能,从而降低满足非功能性需求的风险 如果拒绝了小的修改,但给定时间段内需要修改的总量不变,那么每次变更的规模就会变大 变更规模越大,风险也越大,因为其中涉及的区域越多 由于运维人员尝试避免变更,新功能流入生产环境的速度因此被延缓,从而延缓了开发人员将特性交付给用户使用的速度。

运维人员可能对应用程序内部缺乏了解,从而难以正确地选择运行时环境和发布流程。

开发人员可能对运行时环境缺乏了解,从而难以正确地对代码进行调整。

诉求[编辑] 更小、更频繁的变更──意味着更少的风险 让开发人员更多地控制生产环境 更多地以应用程序为中心来理解基础设施 定义简洁明了的流程 尽可能地自动化 促成开发与运维的协作 一般而言,当企业希望将原本笨重的开发与运维之间的工作移交过程变得流畅无碍,他们通常会遇到以下三类问题: 发布管理问题 很多企业有发布管理问题。

他们需要更好的发布计划方法,而不止是一份共享的电子数据表。

他们需要清晰了解发布的风险、依赖、各阶段的入口条件,并确保各个角色遵守既定流程行事。

发布/部署协调问题 有发布/部署协调问题的团队需要关注发布/部署过程中的执行。

他们需要更好地跟踪发布状态、更快地将问题上升、严格执行流程控制和细粒度的报表。

发布/部署自动化问题 这些企业通常有一些自动化工具,但他们还需要以更灵活的方式来管理和驱动自动化工作──不必要将所有手工操作都在命令行中加以自动化。

理想情况下,自动化工具应该能够在非生产环境下由非运维人员使用。

要开始优化发布流程,可以从问题识别开始:看看上面提到的哪种问题在你的团队中具有最高的优先级。

发布协调人[编辑] 这是企业级IT组织中一个新出现的角色,其主要任务就是协调安排将企业级软件部署到预生产环境。

对发布协调人的需求来自于以下几方面原因: 需要弥合开发与运维的鸿沟 基础设施日益变得复杂:为了运维web应用,需要多层基础设施和多种平台 发布频率上升(由于敏捷和迭代式开发的引入) 分布式团队:位于全球多个地点的、包含外包人员的、混合开发/测试/基础设施的团队 发布协调人的角色(也被称为部署协调人或集成协调人)源自发布管理或发布工程团队。

这个角色与航空交通管制有些类似──实时协调不同团队的行动,有效使用共享的资源(空域、航道、跑道、航站门),达到组织的总体目标(安全起降)。

传统意义上的发布管理往往只关注软件变更的计划与管理,发布协调则需要控制“将特定软件变更发布至生产环境”的整个过程。

这项工作需要系统地管理所有与“将代码构建并部署到生产环境”相关的技术任务,也被称为“发布工程”。

变更管理是跟踪企业IT环境中各种变化──不管是应用程序还是基础设施的变化──的基本原则。

变更管理是ITILv3的核心之一。

参见[编辑] BizDevOps 参考文献[编辑] ^Samovskiy,Dmitriy.TheRiseofDevOps.FubarednessIsContagious.2010-03-02[2011-01-29].(原始内容存档于2011-01-07).  ^Edwards,Damon.WhatisDevOps?.[2011-01-29].(原始内容存档于2012-09-09).  ^Vambenepe,William.SteveBallmergetsCloud.[2011-01-29].(原始内容存档于2011-03-24).  ^Lyman,Jay.DevOpsmixingdev,ops,agile,cloud,opensourceandbusiness.451CAOSTheory.[2011-01-29].(原始内容存档于2015-09-14).  ^WhatDevOpsmeanstome….[2011-01-30].(原始内容存档于2010-12-30).  ^10+DeploysPerDay:DevandOpsCooperationatFlickr.[2011-01-30].(原始内容存档于2011-04-24).  ^SAMSIG:AppliedLeanStartupIdeas:ContinuousDeploymentatkaChing.SDForum.[2011-01-30].(原始内容存档于2011-02-01).  ^AppliedLeanStartupIdeas:ContinuousDeploymentatkaChing.[2011-01-30].(原始内容存档于2010-06-28).  ^DevOpsGroup.LinkedIn.[2011-01-30].(原始内容存档于2011-06-11).  ^DevOpsDays2009Conference.[2011-01-30].(原始内容存档于2010-12-15).  ^Edwards,Damon.DevOpsMeetupRecap.[2011-01-30].(原始内容存档于2012-07-20).  ^Lyman,Jay.DevOpsmixingdev,ops,agile,cloud,opensourceandbusiness.451CAOSTheory.[2011-01-29].(原始内容存档于2015-09-14).  ^VirtualInfrastructureproducts:featurescomparison.WelcometoIT2.0:NextGenerationITinfrastructures.[2011-01-30].(原始内容存档于2011-07-21).  ^Ellard,Jennifer.BringingOrdertoChaosthroughDataCenterAutomation.InformationManagement.SourceMedia,Inc.[2011-01-30].(原始内容存档于2010-06-11).  ^Debois,Patrick.Theleaningoflife-HistoryoftheSilos.[2011-01-30].(原始内容存档于2010-12-13).  外部链接[编辑] WhatIsThisDevopsThing,Anyway?(byPatrickDebois,2010/02/12)(页面存档备份,存于互联网档案馆) 捷伴行Agile(页面存档备份,存于互联网档案馆) 产品 IBMDevOps(页面存档备份,存于互联网档案馆) NolioASAP StreamStepSmartRelease(页面存档备份,存于互联网档案馆) TheControlTierFramework(页面存档备份,存于互联网档案馆) 取自“https://zh.wikipedia.org/w/index.php?title=DevOps&oldid=70562822” 分类:​敏捷軟體開發软件开发软件工程資訊科技管理隐藏分类:​自2014年6月需补充来源的条目拒绝当选首页新条目推荐栏目的条目 导航菜单 个人工具 没有登录讨论贡献创建账号登录 命名空间 条目讨论 不转换 不转换简体繁體大陆简体香港繁體澳門繁體大马简体新加坡简体臺灣正體 查看 阅读编辑查看历史 更多 搜索 导航 首页分类索引特色内容新闻动态最近更改随机条目资助维基百科 帮助 帮助维基社群方针与指引互助客栈知识问答字词转换IRC即时聊天联络我们关于维基百科 工具 链入页面相关更改上传文件特殊页面固定链接页面信息引用本页维基数据项目 打印/导出 下载为PDF打印页面 其他语言 العربيةAzərbaycancaБългарскиবাংলাBosanskiCatalàکوردیČeštinaDanskDeutschEnglishEspañolEestiEuskaraفارسیSuomiFrançaisעבריתMagyarItaliano日本語한국어NederlandsPolskiPortuguêsРусскийСрпски/srpskiУкраїнськаTiếngViệt 编辑链接



請為這篇文章評分?