移动应用遗留系统重构(2)- 架构篇

2023-10-18 06:38

本文主要是介绍移动应用遗留系统重构(2)- 架构篇,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原创 DTO咨询师黄俊彬 CAC敏捷教练 1周前

前言

 

上一篇移动应用遗留系统重构(1)- 开篇我们分享了移动应用遗留系统常见的问题。那么好的实践或者架构设计是怎样的呢?

 

这一篇我们将整理业内优秀的移动应用架构设计,包含微信、淘宝、支付宝以及美团外卖。其中的部分产品也经历过遗留系统的重构改造,具有非常好的参考意义。

 

 

优秀实践

 

微信

 

从微信对外分享的架构演进文章中可知,微信应用其实也是经历了从大单体到模块化的演进。

图片

图片来源 微信Android模块化架构重构实践

 

 

我们看下介绍中后续改造后的架构设计。

 

图片

图片来源 微信Android模块化架构重构实践

 

设计中提到重构主要3个目标

  • 改变通信方式 (API化)

  • 重新设计模块 (中心化业务代码回归各自业务)

  • 约束代码边界 (pins工程结构,更细粒度管控边界)

 

我们可以发现重构后架构比原来的单体应用的一些变化。

  1. 业务模块独立编译调试,耦合度低

  2. 代码复用高,有统一公共的组件库及kernel

  3. 模块职责、代码边界清晰,强约束

 

更多信息可阅读原文,微信Android模块化架构重构实践。

 

手淘

 

从手机淘宝客户端架构探索实践的分享中介绍到手机淘宝从1.0用单工程编写开始,东西非常简陋;到2.0为索引许多三方库的庞大的单工程;再到3.0打破了单工程开发模式实现业务复用。

 

图片

图片来源 手机淘宝客户端架构探索实践

 

淘宝架构主要分为四层,最上层是组件Bundle(业务组件),往下是容器(核心层),中间件Bundle(功能封装),基础库Bundle(底层库)。

 

文章提到架构演化的一些优点及变化很值得深思。

  1. 业务复用,减少人力

  2. 基础复用,做深做精

  3. 敏捷开发,快速试错

 

支付宝

 

在支付宝mPass实践讨论分析一文中,提到支付宝客户端的总体架构图如下。

 

图片

图片来源 

开篇 | 模块化与解耦式开发在蚂蚁金服 mPaaS 深度实践探讨

 

分享文章中介绍到5层架构设计如下:

  • 最底层是支付宝框架的容器层,包括类加载资源加载和安全模块;

  • 第二层是我们抽离出来的组件层,包括网络库,日志库,缓存库,多媒体库,日志等等,简单说这些是一些通用的能力层;

  • 第三层是我们定制的框架层,这是关键部分,是我们得以实现上千人,上千多个工程共同开发一个 App 的基础;

  • 第四层是基于框架封装出来的业务服务层;

  • 第五层便是具体的业务模块,其中每一个模块都是一个或多个具体的工程

 

文章中介绍到关于工程之间的依赖关系的处理比较特别。

 

在支付宝的架构里,编译参与的部分是和运行期参与的部分是分离的:编译期使用 bundle 的接口包,运行期使用 bundle 包本身。bundle 的接口包是 bundle 包的一部分,即刚才说的 bundle 的代码部分。bundle 的资源包同时打进接口包,在编译期提供给另一个 bundle 引用。

 

更多信息可阅读原文,开篇 | 模块化与解耦式开发在蚂蚁金服 mPaaS 深度实践探讨。

 

美团

 

最后看另外一个跨平台技术架构相关的分享,在外卖客户端容器化架构的演进分享中提到了美团外包的整体架构如下。

 

图片

图片来源 外卖客户端容器化架构的演进

 

特别的一点是是采用了容器化架构,根据业务场景及PV,支持多种容器技术。在文末的总结提到,容器化架构相对于传统的移动端架构而言,充分地利用了现在的跨端技术,将动态化的能力最大化的赋予业务。通过动态化,带来业务迭代周期缩短、编译的加速、开发效率的提升等好处。同时,也解决了面临着的多端复用、平台能力、平台支撑、单页面多业务团队、业务动态诉求强等业务问题。但对线上的可用性、容器的可用性、支撑业务的线上发布上提出了更加严格的要求。

 

更多信息可阅读原文,外卖客户端容器化架构的演进。

 

 

总结

 

架构是为了解决业务的问题,没有银弹。但通过这些业内的优秀实践分享,我们可以发现一些优秀的设计范式。

 

  1. 代码复用

  • 公共能力复用,有专门统一管理应用公用的基础能力,如图片、网络、存储能力、安全等

  • 公用业务能力复用,有专门统一管理应用的业务通用组件,如分享、推送、登录等

 

  1. 低耦合,高内聚

  • 业务模块间通过API方式依赖,不依赖具体的模块实现

  • 依赖方向清晰,上层模块依赖下层模块

 

  1. 并行研发

  • 业务模块支持独立编译调试

  • 业务模块独立发布

 

结合这些特点及CloudDisk团队的业务,团队采用的架构设计如下。

 

图片

 

下一篇,移动应用遗留系统重构(3)- 示例篇,我们将继续介绍CloudDisk的业务及团队问题,分析现有的代码。

 

 


 

 

参考

 

微信Android模块化架构重构实践:

https://mp.weixin.qq.com/s/6Q818XA5FaHd7jJMFBG60w

 

手机淘宝客户端架构探索实践:

https://developer.aliyun.com/indexFeed/

 

开篇 | 模块化与解耦式开发在蚂蚁金服 mPaaS 深度实践探讨:

https://mp.weixin.qq.com/s/3ENp_J6sb086QeXf18lYjg

 

外卖客户端容器化架构的演进:

https://tech.meituan.com/2020/09/30/waimai-mobile-architecture-evolution.html

这篇关于移动应用遗留系统重构(2)- 架构篇的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/230846

相关文章

Windows系统宽带限制如何解除?

《Windows系统宽带限制如何解除?》有不少用户反映电脑网速慢得情况,可能是宽带速度被限制的原因,只需解除限制即可,具体该如何操作呢?本文就跟大家一起来看看Windows系统解除网络限制的操作方法吧... 有不少用户反映电脑网速慢得情况,可能是宽带速度被限制的原因,只需解除限制即可,具体该如何操作呢?本文

CentOS和Ubuntu系统使用shell脚本创建用户和设置密码

《CentOS和Ubuntu系统使用shell脚本创建用户和设置密码》在Linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设置密码,本文写了一个shell... 在linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设

电脑找不到mfc90u.dll文件怎么办? 系统报错mfc90u.dll丢失修复的5种方案

《电脑找不到mfc90u.dll文件怎么办?系统报错mfc90u.dll丢失修复的5种方案》在我们日常使用电脑的过程中,可能会遇到一些软件或系统错误,其中之一就是mfc90u.dll丢失,那么,mf... 在大部分情况下出现我们运行或安装软件,游戏出现提示丢失某些DLL文件或OCX文件的原因可能是原始安装包

电脑显示mfc100u.dll丢失怎么办?系统报错mfc90u.dll丢失5种修复方案

《电脑显示mfc100u.dll丢失怎么办?系统报错mfc90u.dll丢失5种修复方案》最近有不少兄弟反映,电脑突然弹出“mfc100u.dll已加载,但找不到入口点”的错误提示,导致一些程序无法正... 在计算机使用过程中,我们经常会遇到一些错误提示,其中最常见的就是“找不到指定的模块”或“缺少某个DL

C语言中位操作的实际应用举例

《C语言中位操作的实际应用举例》:本文主要介绍C语言中位操作的实际应用,总结了位操作的使用场景,并指出了需要注意的问题,如可读性、平台依赖性和溢出风险,文中通过代码介绍的非常详细,需要的朋友可以参... 目录1. 嵌入式系统与硬件寄存器操作2. 网络协议解析3. 图像处理与颜色编码4. 高效处理布尔标志集合

Java中的Lambda表达式及其应用小结

《Java中的Lambda表达式及其应用小结》Java中的Lambda表达式是一项极具创新性的特性,它使得Java代码更加简洁和高效,尤其是在集合操作和并行处理方面,:本文主要介绍Java中的La... 目录前言1. 什么是Lambda表达式?2. Lambda表达式的基本语法例子1:最简单的Lambda表

Python结合PyWebView库打造跨平台桌面应用

《Python结合PyWebView库打造跨平台桌面应用》随着Web技术的发展,将HTML/CSS/JavaScript与Python结合构建桌面应用成为可能,本文将系统讲解如何使用PyWebView... 目录一、技术原理与优势分析1.1 架构原理1.2 核心优势二、开发环境搭建2.1 安装依赖2.2 验

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

SpringShell命令行之交互式Shell应用开发方式

《SpringShell命令行之交互式Shell应用开发方式》本文将深入探讨SpringShell的核心特性、实现方式及应用场景,帮助开发者掌握这一强大工具,具有很好的参考价值,希望对大家有所帮助,如... 目录引言一、Spring Shell概述二、创建命令类三、命令参数处理四、命令分组与帮助系统五、自定

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F