转载地址:http://gold.xitu.io/entry/5693197160b27e9ba8dd505a?from=timeline&isappinstalled=0
随着移动互联网时代的到来,移动技术也随之飞速发展。如今,APP已然成为绝大多数互联网企业用来获取用户的核心渠道。与此同时,伴随着业务量的增长,愈来愈多的APP也在不断地挑战着每一个移动端研发人员的知识深度,而移动端技术人员也在这个不断接受挑战的过程中,成就了今天的移动互联网时代。

饿了么作为一家在O2O领域高速发展的公司,APP面临着多重挑战,如庞大的用户群体、高频高并发的业务、交易即时性等等。饿了么移动端的开发小伙伴在技术和业务的多重压力下,不断推进着饿了么移动端的架构演进。

1
MVC
我们常说,脱离业务谈架构就是纯粹的耍流氓。饿了么移动APP的发展也是其业务发展的一面镜子。

在饿了么业务发展的早期,移动APP经历了从无到有的阶段。为了快速上线抢占市场,传统移动APP开发的MVC架构成了“短平快”思路的首选:
MVC架构

这种架构因简单清晰,容易开发而被大多数人所接受。

在MVC的体系架构中,Controller层负责整个APP中主要逻辑功能的实现;Model层则负责数据结构的描述以及数据持久化的功能;而View层作为展现层负责渲染整个APP的UI。分工清晰,简洁明了。此外,这种系统架构在语言框架层就得到了Apple的支持,所以非常适用于APP的startup开发。

然后,这种架构在开发的后期会由于其超高耦合性,造成Controller层庞大,而这也是一直被人们所诟病。最终的MVC都从Model-View-Controller走向了Massive-View-Controller的终点。

2
Module

Decoupled

“短平快”的MVC架构在早期可以满足饿了么移动APP的快速开发迭代,但是随着代码量的不断增加,臃肿的Controller层也在渐露头角;而业务上,饿了么移动APP也从单一APP发展为多APP齐头并进的格局。这时候,降低耦合,复用已有模块便成了架构的第一要务。

架构中,模块复用的第一要求便是代码的功能组件化。组件化意味着拥有独立功能的代码从系统中进行抽象并剥离,再以“插件”的形式插回原有系统中。这样剥离出来的功能组件,便可以供其他APP使用,从而降低系统中模块与模块之间的耦合性;也同时提高了APP之间代码的复用性。

饿了么移动对于组件有两种定义:公有组件和业务组件。公有组件指的是封装得比较好的一些SDK,包括一些第三方组件和自己内部使用的组件。如iOS中最著名的网络SDK AFNetworking,Android下OKHttp,都是这类组件的代表。业务组件,则定义为包含了一系列业务功能的整体,例如登录业务组件,注册业务组件,即为此类组件的典型代表。

对于公有组件,饿了么移动采取了版本化的管理方式,而这在iOS和Android平台上早有比较成熟的解决方案。例如,对于iOS平台,CocoaPods基本上成为了代码组件化管理的标配;在Android平台上,Gradle也是非常成熟和稳健的方案。采用以上管理工具的另一个原因在于,对企业开发而言,代码也是一种商业机密。基于保密的目的,支持内网搭建私有服务器成为了必需。以上的管理工具都能够很好地支持这些操作。

对于业务的组件化,我们采取了业务模块注册机制来达到解耦合的目的。每个业务模块对外提供相应的业务接口,同时在系统启动的时候向Excalibur系统注册自己模块的Scheme(Excalibur是饿了么移动用来保存Scheme与模块之间映射的系统,同时能根据Scheme进行Class反射返回)。 当其他业务模块对该业务模块有依赖时,从Excalibur系统中获取相关实例,并调用相应接口来实现调用,从而实现了业务模块之间的解耦目的。

而在业务组件,即业务模块的内部,则可以根据不同开发人员的偏好,来实现不同的代码架构。如现在讨论得比较火的MVVM, MVP等,都可以在模块内部进行而不影响整体系统架构。

这时候的架构看起来更像是这样:

E(Excalibur)M(Modules)C(Common)架构以高内聚、低耦合为主要的特点,以面向接口编程为出发点,降低了模块与模块之间的联系。

该架构的另外一大好处则在于解决了不同系统版本的兼容性问题。这里以iOS平台下的WebView作为例子来进行说明。Apple从iOS8系统开始提供了一套更好的Web支持框架——WebKit,但在iOS7系统下却无法兼容,从而导致Crash。使用此类架构,可以在iOS7系统下仍然注册使用传统的WebView来渲染网页,而在iOS8及其以上系统注册WebKit来作为渲染网页的内核。既避免了Apple严格的审核机制,又达到了动态加载的目的。

3
Hybrid
移动APP的开发有两种不同的路线,NativeAPP和Web APP。这两种路线的区别类似于PC时代开发应用程序时的C/S架构和 B/S架构。

以上我们谈到的都属于典型的Native APP,即所有的程序都由本地组件渲染完成。这类APP优点是显而易见的,渲染速度快、用户体验好;缺点同时也十分突出:出现了错误一定要等待下一次用户进行APP更新才能够修复。

Web APP的优点恰好就是Native APP的缺点所在,其页面全部采用H5撰写并存放在服务器端。每次进行页面渲染时都从服务器请求最新的页面。一旦页面有错误,服务器端进行更新便能立刻解决。不过其弊端也容易窥见:每次页面都需要请求服务器,造成渲染时等待时间过长,从而导致的用户体验不够完美,并且性能上较Native APP慢了1-2个数量级;与此同时还会导致更多的用户流量消耗。另一个缺点则在于,Web APP在移动端上调用本地的硬件设备存在一定的不便。不过这些弊端也都有相应的解决方案,如PhoneGap将网页提前打包在本地以减少网络的请求时间;同时也提供一系列的插件来访问本地的硬件设备。然而,尽管如此,其渲染速度上还是存在一定的差距。

Hybrid APP则是综合了二者优缺点的解决方案。饿了么移动对于此二类APP的观点在于,纯粹展示性的模块会更适合使用Web页面来达到渲染的目的;而更多的数据操作性、动画渲染性的模块则更适合采用Native的方式。

基于之前的EMC架构,我们将部分模块重新进行了架构:

Hybrid EMC架构
Hybrid-EMC架构中,Web作为一个子模块,注册加入到整个系统中,从而让业务上需要快速迭代的模块实现实时更新。

4
React-Native

& Hot Patch

经过这些年的业务发展,Hybrid提供的展示界面更新方案也逐渐地无法满足APP更新迭代的需要。因此越来越多动态部署的方案被提了出来,比如iOS下的JSPatch, waxPatch,Android下的Dexpose, AndFix, ClassLoader,都是比较成熟Hot Patch动态部署解决方案。这些方案的思路都是通过下载远程服务器的代码来动态更新本地的代码行为。

React-Native则属于另一种动态部署的方案,其核心原理在于通过JavaScript来调用本地组件进行界面的渲染。

而饿了么移动APP发展到今天,各个APP综合用户量已经过亿。因此一个非常小的Bug所带来的问题都可能会直接影响到几万人的使用。为了保证APP的稳定性和健壮性,Hot Patch方案也就成了当下最有待解决的问题。

根据80%的用户访问20%页面这一80/20原则,保证这20%访问最频繁的页面的稳定性就是保证了80%的APP的稳定性。因此,饿了么移动对于部分访问最频繁的模块进行了React-Native备份。当这部分页面出现问题时,APP可以通过服务器的配置,自动切换成React-Native的备份页面;而与此同时开发人员开发一个小而精的Hot Patch来修复出现的问题。当Hot Patch完成修补后,再切换回Native APP的原生功能。

这时候的架构看起来会像是这样:

HotPatch-EMC架构
HotPatch-EMC的架构主要目标在于解决移动APP的稳定性问题。通过RN与Native的主备,可以减少系统APP出错带来的失误。

结语

我们都知道,对于软件工程来说,这世上没有银弹。这对于架构而言其实也非常的适用。移动技术的不断发展和业务的不断变化,推动了饿了么移动APP架构的不断演进。

架构没有真正的好坏之分,只要适用于自己的业务,就是好的架构!

文/饿了么移动技术 王朝成 胡彪

饿了么移动 APP 的架构演进相关推荐

  1. 饿了么移动APP的架构演进(转)

    原文:http://www.jianshu.com/p/2141fb0dc62c 文/圣迪(简书作者) 原文链接:http://www.jianshu.com/p/2141fb0dc62c 著作权归作 ...

  2. 新东方APP技术架构演进, C端技术经验分享

    新东方APP技术架构演进, C端技术经验分享 作者:张建鑫, 曾任IBM高级软件架构师, 滴滴高级技术专家, 现任新东方集团高级技术总监 古代东西方的思想家都产生过一个终极的追问,世界的本元到底是什么 ...

  3. 淘宝 APP 网络架构演进与弱网破障实践

    作者:沈良炜 阿里大淘宝终端体验平台团队 面对移动互联网络下复杂多变的网络环境,如何提供更稳定可靠的请求性能,保障用户的加载浏览体验?本文将为大家分享淘宝APP统一网络库的演进. 一.引言 自2013 ...

  4. 最右App:架构演进之路

    摘要:本次阿里云云栖社区行业圆桌论坛上,最右App技术总监许林.阿里云技术专家张翔贺.高级技术专家闵庆欢共同探讨了最右App的上云实践之路,并且分享了最右App在移动加速和个性化推荐以及安全方面实战经 ...

  5. 网易严选APP工程架构演进

    一.前言 互联网技术发展到今天,移动互联网仍然是一个重要的战略核心,APP也仍然是绝大多数互联网企业用户获客留存的核心渠道. 根据2021年移动应用趋势报告[1],移动应用程序的受欢迎程度仍在持续增长 ...

  6. 苏宁易购 App 客户端架构演进

    点击上方"开发者技术前线",选择"星标" 13:21 在看 真爱 作者:李呈武 | 来源:前端之巅 摘要 一个电商类 APP,对用户而言,是琳琅满目的商品,是层 ...

  7. 饿了么移动App 演进

    饿了么移动APP的架构演进-https://mp.weixin.qq.com/s?__biz=MzAxNDUwMzU3Mw==&mid=401044540&idx=1&sn=2 ...

  8. [2016.10.17日更新]各大互联网公司架构演进之路汇总

    大型网站架构演化历程 大型网站架构技术一览 Web 支付宝和蚂蚁花呗的技术架构及实践 支付宝的高可用与容灾架构演进 聚划算架构演进和系统优化 (视频+PPT) 淘宝交易系统演进之路 (专访) 淘宝数据 ...

  9. 各大互联网公司架构演进之路汇总

    大型网站架构演化历程 大型网站架构技术一览 Web 支付宝和蚂蚁花呗的技术架构及实践 聚划算架构演进和系统优化 (视频+PPT) 淘宝交易系统演进之路 (专访) 淘宝数据魔方技术架构解析 淘宝技术发展 ...

  10. [10.17日更新]各大互联网公司架构演进之路汇总

    一篇不错的大型网站架构文章及视频汇总资料, 文章出处:http://www.hollischuang.com/archives/1036 大型网站架构演化历程 大型网站架构技术一览 Web 支付宝和蚂 ...

最新文章

  1. R语言ggplot2可视化:绘制堆叠的密度图(Stacked Area Chart)
  2. BIOS不识别linux,linux – 在BIOS中启用VT但KVM无法检测到
  3. mvc tips:在模板页中使用javascript
  4. 【最简便解法】1086 就不告诉你 (15分)_13行代码AC
  5. 内蒙古计算机专修学院单招,内蒙古电子信息职业技术学院单招多少分能上?
  6. 简述HTML语言概念,HTML语言的基本概念和基本格式.doc
  7. Linux 不小心删除了 root,root目录不小心删除了怎么办……
  8. iOS开发:icon和启动图尺寸(转)
  9. 树莓派外接显示器黑屏_解决树莓派使用HDMI-VGA转换器黑屏的方案
  10. Wireshark-Mac下找不到本地网卡
  11. 希尔伯特变换的本质是什么?
  12. 【Python】Python调用Java jar包方式 ——Jpype使用
  13. 多个版本的BIND DNS软件都存在一个严重漏洞
  14. Java的重写和重载
  15. BP神经网络学习与代码预演
  16. 深入讨论机器学习 8 大回归模型的基本原理以及差异!
  17. 一位博士在华为的22年
  18. WhatsAPP营销详细攻略,带你一镜到底的了解WhatsAPP营销
  19. android 使用icon进行字符编码转换
  20. 增强学习(Q-learning)

热门文章

  1. STM8L152C6T6+IAP详解,包教包会
  2. 二进制转格雷码c语言编程,格雷码简介及格雷码与二进制的转换程序
  3. 安全龙网络安全攻防实验1.2 全新功能正式上线
  4. java实现电子面单pdf生成_电子面单打印功能实现方法
  5. HTML静态网页作业——动漫火影忍者 (HTML+CSS)制作个人主页课程设计
  6. 【python】websockets
  7. numpy - 数组随机排序
  8. 使用hydra离线破解windows密码
  9. Oracle | awr报告分析
  10. mysql awr报告生成_批量生成AWR报告(转载总结)