SDKHotFix
Introduction: 在用户规模千万级别的 app 中验证过,稳定无兼容问题,5 分钟让你的 SDK 拥有热修复能力。A SDK hotfix library with stable verified in tens of millions of users can be accessed in only five minutes.
Tags:
在用户规模千万级别的 app 中验证过,稳定、无兼容问题,5 分钟即可接入,满足你的 SDK 快速拥有热修复能力的需求。
目录
- 一、介绍
- 作用
- 优点
- 待改进
- 二、接入指南
- 三、使用指南和演示
- 四、原理
- 五、相关文章
- 六、改进说明
一、介绍
相信 APP 热修复大家都很熟练了,那如果 SDK 想要实现热修复呢?
这就是本项目诞生的背景,让 SDK 开发者能快速赋予 SDK 热修复的能力,不要踩我踩过的坑。(捂脸哭)
作用
如果你是 SDK 开发者,你能得到什么?
- 5 分钟即可让你的 SDK 拥有热修复的能力
- 节省踩坑和开发成本
如果你是一个学习者,你能通过这个项目学到什么?
- hook and create Gradle Task
- Kotlin + groovy
- 热修复
- 非对称加密+对称加密
- 扩展美团 Robust 开源库,使其具有其他热更库不具备的补丁回滚功能
- 数据和监控思维
优点
- 无兼容问题
- 实时生效
- 修复成功率高达 99.9%
- 在用户规模千万级别的 app 中验证过,可信赖
- 支持补丁异常自动失效,不用再担心补丁造成 crash 啦~
待改进
- 在编译阶段插件侵入了产品代码,对运行效率、方法数、包体积还是产生了一些副作用。(可指定某些 class 无需插入方法,减少插桩数)
- so 和资源的替换目前暂未实现
- 对于只有字段访问的函数无法直接修复,可通过调用处间接修复
- 上传 GradleTask 尚未在 MAC 环境下测试
- 上传的补丁支持按包名存档
- 要商用的小伙伴要注意,建议换成自己的后端接口或自己续费一个 bmob 应用,因为 bmob 云函数服务超过 40 天需要收费,所以本项目需要定期更新应用秘钥。
二、接入指南
点击SDK 热修复 SDK 接入文档,开始接入吧!
关于常见问题的解决,请参看 Wiki
三、使用指南和演示
-
用于业务 SDK 接入
-
用于接入后 SDK 的打包、补丁代码的编写、下发、上传。
-
常见问题和异常汇总,遇到问题前请先自查
Module 说明:
- SDKHotFix\APP:调试 HotfixSDK 用
- SDKHotFix\buildSrc:upload 补丁用
- SDKHotFix\SDK:赋予业务 SDK 热修复能力的 SDK
- SDKHotFix\business_sdk\APP:模拟业务 app 接入了有热修复能力的业务 SDK,上述 gif 的演示效果即是本示例
- SDKHotFix\business_sdk\samplesdk:模拟业务 SDK 如何接入 SDKHotFix,上述 gif 的演示效果即是本示例
四、原理
五、相关文章
六、改进说明
- 稳定性提升:
- fix 若干 bug
- fix 与业务方的资源 ID 冲突问题
- 便捷性提高:
- 使用 gardle Task 脚本上传补丁,比起 Window 程序更方便
- 抽取成库,业务 SDK 只需要最小步骤即可快速接入
- 支持度提高:
- 使用了阿里云 oss 管理补丁
- 支持了打包 SDK 后上传 jcenter