写点什么

从基于 Web 的应用到原生应用的迁移看 Facebook 的发布流程

  • 2014-01-05
  • 本文字数:1011 字

    阅读完需:约 3 分钟

来自 Facebook 的 Chaitanya Mishra 在上月的 Velocity Conf London 上发表了演讲,描述了Facebook 将其Android 应用从Web View 视图转换为全面原生应用的方法。为了达成该目标,各个产品团队只负责自己特性。为了使分布开发模型能够正常工作,由一个核心团队负责回归测试并专注于整体应用的优化而不是某个特性的优化。

因为对于用户来说,升级到应用的新版本(包括修复)决定于第三方的审核以及用户想升级的想法,所以需要对适用于 Web 开发持续交付模型做一些调整,使其适用于快速迭代的 Android 开发。当构建失败时快速反映给开发人员,内部试用新发布版本(在发布到应用商店的 4 周之前先内部发布给员工试用)并监测其使用情况(碰到功能错误或性能问题时及时反馈给开发人员),该措施提升了对外发布的信心。在这 4 周时间里,在一个发布分支中修复问题,该分支与主分支(在主分支中不断加入并测试新功能,作为将来的发布功能)是并行的。

除了功能和性能测试(使用 Selendroid 通过界面进行)外,其他在构建过程中针对 Android 应用的检查还包括:应用的大小(是否有变更会意外增加应用的大小),内存使用率以及电源消耗(实际的电池使用)。Chaitanya 举了一个例子,团队发现一个很明显的电源消耗增大却又无法解释的问题,最终证明是一个微不足道的变更导致的,该变更是为了阻止应用进入休眠模式而采用的轮询机制。

应用发布出去之后,Facebook 使用 Analytics Logger 监控应用的性能和问题。反馈的数据使用一种叫做 Scuba 的工具进行分析。Chaitanya 又举了个例子,他们发现数据库崩溃的次数越来越多。他们怀疑是用户设备的可用空间过低导致的,所以他们就增加了剩余空间检测功能,结果发现确实是应用占用了过多的空间,这都是应用分配甚至复制整个数据库,超大缓存,还有一些不必要的文件导致的。问题经过修复后,数据库崩溃的频率明显降低。

尽管应用已经成功转换为完全本地化应用,但是让 Chaitanya 担心的是,向本地化转化后不稳定现象会偶尔出现,尤其是一些不常用的功能还是基于 Web 实现的。根据 Chaitanya 的说法,依赖 Web 的缺点是需要尽可能保持与网站 API 的向后兼容。

查看英文原文: Facebook’s Release Process Behind the Move from Web-based to Native App


感谢张龙对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ )或者腾讯微博( @InfoQ )关注我们,并与我们的编辑和其他读者朋友交流。

2014-01-05 06:042113
用户头像

发布了 28 篇内容, 共 10.2 次阅读, 收获喜欢 0 次。

关注

评论

发布
暂无评论
发现更多内容

软件架构师应该具备哪些素质?

漫步跑小鸡

架构师训练营第一周 - 作业

kk

极客大学架构师训练营

【架构课作业-第一周】食堂就餐卡系统设计

Nelson

极客大学架构师训练营

食堂就餐卡系统设计

Arthur.Li

极客大学架构师训练营 UML

第一周作业一:食堂就餐卡系统设计

Larry

架构师训练营第一周-总结

butterfly

架构师训练营-第一周学习总结

zongbin

架构总结

【总结】如何成为架构师

Geek_165f3d

作业二:架构师训练营 -第一周

亮灯

极客时间-作业一-学习总结

刘柯

架构师训练营第一周【学习总结】

小K

极客大学架构师训练营

如何让自己有机会成为一名架构师?

kk

极客大学架构师训练营

架构训练学习总结一

mylove321

软件架构师的设计语言

dony.zhang

架构师训练营0期Week1作业

theivanxu

极客大学架构师训练营

架构图学习总结

阿布

架构师训练营0期Week1总结

theivanxu

食堂就餐系统

安阳

「架构师训练营」第 1 周作业 - 食堂就餐卡系统设计

butterfly

【总结】架构师如何做架构

张金峰

极客大学架构师训练营

食堂就餐卡系统设计

种个大西瓜

架构师训练营——食堂就餐卡系统设计

养乐多

架构师训练营第1周学习总结

一叶知秋

食堂就餐卡系统架构设计图

阿布

架构师训练营第一周-学习总结

海滨

架构师训练营 第一周 总结 架构师与架构

CR

极客大学架构师训练营

【第一周】架构训练营总结

星星

架构师第一周作业

suke

极客大学架构师训练营

架构师训练营第一周【作业】

小K

架构师训练营-食堂就餐卡系统设计

zongbin

架构文档

第一周作业一:食堂就餐卡系统设计

田振宇

从基于Web的应用到原生应用的迁移看Facebook的发布流程_Meta_Manuel Pais_InfoQ精选文章