移动应用遗留系统重构(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

相关文章

Mac系统下卸载JAVA和JDK的步骤

《Mac系统下卸载JAVA和JDK的步骤》JDK是Java语言的软件开发工具包,它提供了开发和运行Java应用程序所需的工具、库和资源,:本文主要介绍Mac系统下卸载JAVA和JDK的相关资料,需... 目录1. 卸载系统自带的 Java 版本检查当前 Java 版本通过命令卸载系统 Java2. 卸载自定

CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比

《CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比》CSS中的position属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布... css 中的 position 属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布局和层叠关

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

基于Python实现一个简单的题库与在线考试系统

《基于Python实现一个简单的题库与在线考试系统》在当今信息化教育时代,在线学习与考试系统已成为教育技术领域的重要组成部分,本文就来介绍一下如何使用Python和PyQt5框架开发一个名为白泽题库系... 目录概述功能特点界面展示系统架构设计类结构图Excel题库填写格式模板题库题目填写格式表核心数据结构

Linux系统中的firewall-offline-cmd详解(收藏版)

《Linux系统中的firewall-offline-cmd详解(收藏版)》firewall-offline-cmd是firewalld的一个命令行工具,专门设计用于在没有运行firewalld服务的... 目录主要用途基本语法选项1. 状态管理2. 区域管理3. 服务管理4. 端口管理5. ICMP 阻断

Python使用Tkinter打造一个完整的桌面应用

《Python使用Tkinter打造一个完整的桌面应用》在Python生态中,Tkinter就像一把瑞士军刀,它没有花哨的特效,却能快速搭建出实用的图形界面,作为Python自带的标准库,无需安装即可... 目录一、界面搭建:像搭积木一样组合控件二、菜单系统:给应用装上“控制中枢”三、事件驱动:让界面“活”

Windows 系统下 Nginx 的配置步骤详解

《Windows系统下Nginx的配置步骤详解》Nginx是一款功能强大的软件,在互联网领域有广泛应用,简单来说,它就像一个聪明的交通指挥员,能让网站运行得更高效、更稳定,:本文主要介绍W... 目录一、为什么要用 Nginx二、Windows 系统下 Nginx 的配置步骤1. 下载 Nginx2. 解压

如何确定哪些软件是Mac系统自带的? Mac系统内置应用查看技巧

《如何确定哪些软件是Mac系统自带的?Mac系统内置应用查看技巧》如何确定哪些软件是Mac系统自带的?mac系统中有很多自带的应用,想要看看哪些是系统自带,该怎么查看呢?下面我们就来看看Mac系统内... 在MAC电脑上,可以使用以下方法来确定哪些软件是系统自带的:1.应用程序文件夹打开应用程序文件夹

windows系统上如何进行maven安装和配置方式

《windows系统上如何进行maven安装和配置方式》:本文主要介绍windows系统上如何进行maven安装和配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录1. Maven 简介2. maven的下载与安装2.1 下载 Maven2.2 Maven安装2.

使用Python实现Windows系统垃圾清理

《使用Python实现Windows系统垃圾清理》Windows自带的磁盘清理工具功能有限,无法深度清理各类垃圾文件,所以本文为大家介绍了如何使用Python+PyQt5开发一个Windows系统垃圾... 目录一、开发背景与工具概述1.1 为什么需要专业清理工具1.2 工具设计理念二、工具核心功能解析2.