随着京东金融业务的不断拓展,客户端开发团队人数激增,代码量急剧膨胀,业务的成长和人员的倍增给技术架构、团队合作、产品的交付都带来了巨大的挑战,本文将讲述京东金融移动APP是如何保证高效、稳定、安全、高质量的持续交付,希望借此机会向大家分享经验与教训,与大家共同探讨移动APP高质量持续交付之道,在讨论移动APP持续交付之前先介绍一下京东金融研发协同平台。
京东金融研发协同平台(简称JCI)致力于将构建、部署、测试、发布的过程自动化,以此来帮助用户高效且安全地交付研发成果;JCI集成了应用管理、组件管理、移动APP管理、产品管理、代码管理、编译构建管理、发布管理、审批管理等功能,从研发协同、代码质量、安全、快速交付、测试及结果反馈等几个方面打造了一条完整的工具链。
移动APP持续交付模块作为JCI最重要的模块之一,将测试、编译打包,发版、构建渠道包,上传生产服务器等手工操作实现了完全自动化,让整个交付过程变得可靠、可预期、可视化、改变了移动APP的交付方式,让开发人员从琐碎的重复劳动中解放出来。
什么是持续交付?我们如何定义持续交付的呢?用通俗点的话讲,持续交付是指研发能够快速、安全、频繁的向客户交付价值,以便尽早得到生产环境中反馈的问题。
移动APP持续交付平台的核心就是建设可靠可重复的交付流水线,通过交付流水线,将全局过程标准化、自动化、可视化,关键流程和节点管控,实现并行开发过程中的协同和管理。
整个交付过程把需求、开发、集成、测试、发布一体化;各个阶段相互独立,并加入规范化的流程。
随着业务的增加,代码功能稳步上升, 合并代码全靠开发线下进行,代码合并时间呈指数级上升,效率极低且容易出错,因此需要在架构上进行组件化拆分,使每一个组件都有一个自己独立的工程,解决协同合作的问题,提升研发效率。
另外就是二进制交付,比如说我们有一个APP有十几万行代码,本次发版修改了1000行代码,传统的源码交付的方式,是需要将这十几万行代码全部重新编译一次,才能产生这个APP,效率特别低下,如果能做到二进制的交付,也就是只需要交付增量的部分,这1000多行代码可能也就涉及到几个模块,这几个模块加在一起可能也就几千行代码,我们当前需要交付的就是这几千行代码的模块就可以了,由十几万行代码变成几千行代码的交付。
最后是依赖管理,它本身是依赖前面的二进制交付,前提是将整个APP都拆分成了模块,对交付而言只需要更新其中几个模块,这几个模块就可以通过依赖管理来管起来。
持续交付平台是一个一站式的全生命周期的管控平台,它提供了从开发到构建、测试、发布、运维、运营的全生命周期的管控,集成了开发规范、测试规范、发布规范,也是一个效率提升和质量提升的平台,在移动APP这个领域我们还有很多问题没有解决,前方的道路依然坎坷,我们会更加努力,并不断前行。