系统架构之组件化、插件化和热修复

一、背景

        公司里的产品层负责尝试、预测和理解用户的喜好,技术层也需要思考如何支持快速试错,反馈调整,帮助业务线不断前行,因此产生出新需求,

  1. 希望业务越来越丰富,但不期望逻辑越来越臃肿
  2. 希望支撑业务快速试错,但不期望频繁升级的叨扰用户
  3. 需要很大程度改变程序架构,但不能停止需求迭代,不能过分冒险,需要综合考虑团队整体的学习曲线

所以,落实到技术方案目标:期望实现一个支持热更新,可以把业务分拆为可单独试错的插件化服务集合,支持服务运营,不断分析用户数据的大数据思路调优服务重点。

二、概念

1、组件化
将一个app分成多个模块,组件化强调功能拆分,单独编译,单独开发,根据需求动态配置业务组件

2、插件化
将整个app拆分成很多模块,这些模块包括一个宿主和多个插件,每个模块都是一个apk(组件化的每个模块是个lib),最终打包的时候将宿主apk和插件apk分开或者联合打包,插件化更关注动态扩展、热更新(热修复)

3、热修复(热更新)
通过发布补丁包,在不需要二次安装应用的前提下修复已知的bug

组件化与插件化.png

热修复原理.png

技术单位解决痛点特性加载状态优点缺点典型框架
组件化module(模块)解耦模块,加快编译,隔离不关注的部分组件之间低耦合,可独立或组合组件编译打包静态加载

1、组件独立运行

2、代码复用性高

3、明确业务边界,代码结构更清晰

1、开发前期大量时间做模块拆分

2、可能会带来更多重复的代码

CC/阿里ARouter
插件化apk解耦模块,加快编译,可实现热更新每个插件能作为完全独立的apk运行,也可组合集成为一个apk动态加载,只有真正使用某个插件时才加载

1、支持热部署、支持多业务自然的分拆

2、复用Android API,能在满足动态的同时,提供native的体验

3、宿主和插件分开编译

4、按需下载模块

5、减小APK体积

1、使用大量反射实现,稳定性差

2、插件和宿主一起打包,每次更新宿主,插件都要重新下载

3、只适用于android,无法与ios保持方案统一

携程DynamicAPK/任玉刚dynamic-load-apk/轻量级Small/360DroidPlugin、RePlugin/滴滴VirtualAPK/腾讯Shadow

热修复/

热更新

.class或资源文件动态修复bug相比于插件化,仅提供修复bug功能动态加载,无需冷启动就可修复bug腾讯Tinker/饿了么Amigo/美团Robust/阿里AndFix/Qzone等

由此得出,

  • 组件化拆分是实现插件化的必经之路,组件化是编译期分模块,插件化是在运行期
  • 对于热修复,多模块插件分拆发力不够,插件化能做到的事情更多

三、插件化技术对比

        尽管对比可知插件化更贴合目前开发系统的需求,但插件化代表一种热更新、分拆的概念,具体实现技术很多。技术没有绝对的好坏,终究还是要回归到场景和需求驱动。当进行技术选型时,一定不是跟风,跟热,而是关注负责的业务。

  • 25
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值