美团热修复Robust的踩坑之旅-使用篇

  最近需要在项目中使用热修复框架,在这里以美团的Robust为主写一篇文章总结一下学习的过程。

  一直认为要学习一个框架的原理,首先需要让他跑起来,从效果反推回去,这样更容易理解。  

一、美团Robust的使用

  首先我们在编写代码前需要做如下准备

  配置文件读写权限,6.0以上需要手动获取

  

   <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"></uses-permission>
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"></uses-permission>
    <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" />

  在project的gradle文件中编写如下代码

  

  在module的gradle文件中编写如下代码

  

  

  同时我们将从github上下载的美团Robust的例子中的robuts.xml复制到我们的项目中

  将下面两个地方改为我们的包名,其他地方不建议在新手测试的时候进行修改。

  

  

  同时要记得将App的混淆打开,原因在后面会提到

  

    到目前为止,我们可以开始代码方面的编写了

  首先给大家看一下目录结构

  

  首先我们看MainActivity的代码

  

  界面很简单,一个TextView和两个Button,图片在后面

这里面重要的就是这个newPatchExecutor,传入了我们写的PatchManpulateImp,和一个回调。

  我们接下来看PatchManpulateImp这个类。

  这里我们可以将美团的PatchManpulateImp类复制下来,稍微修改一下就可以了

  

  这里改为“你的包名”+PatchesInfoImpl即可

  

  RobustActivity里面的代码很简单如下

  

  这里全部完成后我们可以开始生成apk了,这里要注意要生成带签名的apk-release。

  

  这里要注意的是生成带签名的release apk时,要同时勾选v1,v2。不然一会通过adb命令想genymotion安装App时会报错。

  生成Apk后我们通过adb命令将apk安装到模拟器上,这里有的同学可能发现adb无法使用,需要在系统中设置环境变量,adb工具在androidsdk中自带,可以在sdk中去找。

  

  

  接下来是补丁生成的流程

  生成apk后我们可以看到Robust给我们生成了如下文件。新建一个与src同级的文件夹robust,将这两个文件复制过去,这里要注意我们在前面如果没配置混淆的话,这两个文件是不会出现的。

  

  

  将我们前面的gradle文件打开,修改如下

  

  然后修改RobustActivity中的代码如下

  

  在terminal中调用如下命令

  gradlew clean assembleRelease --stacktrace --no-daemon

  生成补丁包

  这里会build失败,不影响,有下列即为成功,我们可以看到这里已经生成了补丁包

  

  现在我们把补丁包push到我们的模拟器中

  这里面我们push jar包到我们在PatchManpulateImp中设置的地址的前一级

 

  现在我们开始运行程序,先点击加载jar包,这里要注意Anroid6.0以上要手动开启读取写入权限。

  

  

  这样我们就成功了。若是运行失败,建议去看一看打印出的异常,具体分析原因。

二、小结

  在接下来的分析中,将会分析美团Robust的原理。

  

  

  

  

  

原文地址:https://www.cnblogs.com/yrstudy/p/8973394.html

时间: 2024-10-01 00:20:24

美团热修复Robust的踩坑之旅-使用篇的相关文章

Python 踩坑之旅进程篇其四一次性踩透 uid euid suid gid egid sgid的坑坑洼洼

目录 1.1 踩坑案例 1.2 填坑解法 1.3 坑位分析 1.4 技术关键字 1.5 坑后思考 下期坑位预告 代码示例支持 平台: Centos 6.3 Python: 2.7.14 代码示例: 菜单 - Python踩坑指南代码示例 1.1 踩坑案例 小明是个服务器管理员, 他从老管理员手里接手了一个非常繁琐的运维工作: 短暂授权root 账号给不同的 team 接口人运行备份任务 该运维任务有几个特点: 任务需且仅需运行在 root 下 root 账号只能短暂授权给各个小组 通过账号管理平

Zabbix 踩坑之旅——zabbix触发重启tomcat

一.实验需求 公司tomcat服务经常自动崩溃,导致业务中断,暂时用zabbix对其执行监控,在tomcat崩溃时能够先自动启动,保证业务尽快恢复正常. 二.准备环境 系统环境:CentOS 6.5 IP地址: zabbix-server: 192.168.239.128 zabbix-agent: 192.168.239.130 zabbix的服务端和客户端的安装此处都以rpm包安装,配置略过.agent端上安装好tomcat. 三.开启踩坑之旅--agent端 ① 修改zabbix-agen

vue+ vue-router + webpack 踩坑之旅

说是踩坑之旅 其实是最近在思考一些问题 然后想实现方案的时候,就慢慢的查到这些方案   老司机可以忽略下面的内容了 1)起因  考虑到数据分离的问题  因为server是express搭的   自然少不了res.render("xx",data)    这句话的意思就是去查找相应的模板文件然后在用数据去渲染在将渲染好的页面去返回给浏览器,给浏览器去解析,渲染模板其实就是做的替换字符串+拼接字符串的活  各种的模板引擎也有各个优化的点(比如可以将对应的模板编译的函数保存在内存中,然后在通

一次痛苦又甜蜜的微信支付踩坑之旅

凡是和钱打交道的事,没有一样是容易的.这是我第一次接触微信支付,发现网上还是有很多同学在求助,XXX了怎么办?XXX是什么情况?为了帮助更多的小伙伴脱离"苦海",我决定写下这次的踩坑之旅,给更多的人帮助. 介绍 微信支付方式分为刷卡支付.公众号支付.扫码支付.APP支付.H5支付.小程序支付. 先从应用场景来各自说一说,这样,能够最快的判断出应该选择哪一种支付. 刷卡支付:使用扫描设备(扫描枪)多见于超市.便利店使用 公众号支付:嵌入公众号的H5页面 扫码支付:用户打开"微信

小程序踩坑之旅

小程序踩坑之旅 —— 分包 小程序踩坑之旅 —— 分享 小程序踩坑之旅 —— 页面路由 小程序踩坑之旅 —— canvas 原文地址:https://www.cnblogs.com/xxhuan/p/11334792.html

聊聊Android 热修复Nuwa有哪些坑

原创地址:http://blog.csdn.net/sbsujjbcy/article/details/51028027 前面写了两篇关于Nuwa的文章 Android 热修复Nuwa的原理及Gradle插件源码解析 Android 热修复使用Gradle Plugin1.5改造Nuwa插件 然后我说了Nuwa有坑,有人就问Nuwa到底有哪些坑,这篇文章对自己在Nuwa上走过的坑做一个总结,如果你遇到了其他坑,欢迎留言,我会统一加到文章中去.当然有些也不算是Nuwa的坑,算是ClassLoade

Python踩坑之旅其一杀不死的Shell子进程

1.1 踩坑案例 踩坑的程序是个常驻的Agent类管理进程, 包括但不限于如下类型的任务在执行: a. 多线程的网络通信包处理 和控制Master节点交互 有固定Listen端口 b. 定期作业任务, 通过subprocess.Pipe执行shell命令 c. etc 发现坑的过程很有意思: a.重启Agent发现Port被占用了 => 立刻想到可能进程没被杀死, 是不是停止脚本出问题 => 排除发现不是, Agent进程确实死亡了 => 通过 netstat -tanop|grep p

百度地图sdk踩坑之旅

1.写在前面 项目中需要加上路线规划,导航,添加覆盖物,因为我最开始项目中定位我使用的是百度定位,所以为了省事,接着使用百度地图sdk实现这些.这两天踩了很多百度地图的坑,记下来.因为一些原因,后面会说,需求还没做完,所以效果图很简单,如下. 2.坑1,环境配置 对于百度地图sdk的配置我是无语.因为一开始项目中并没打算使用百度地图其他功能,只是准备定位.所以我下载sdk时只是下载了定位的sdk,如图 现在需要加上地图和导航的sdk(后面才知道导航并不需要下载专门的导航sdk,因为地图sdk可以

Ubuntu搭建Hadoop的踩坑之旅(三)

之前的两篇文章介绍了如何从0开始到搭建好带有JDK的Ubuntu的过程,本来这篇文章是打算介绍搭建伪分布式集群的.但是后来想想反正伪分布式和完全分布式差不多,所幸直接介绍完全分布式了. 如果你想自己搭建伪分布式玩的话,参考:在VMware下安装Ubuntu并部署Hadoop1.2.1分布式环境 - CSDN博客 这一篇主要参考这篇文章:Hadoop2.6.0安装 - 集群(搭建的过程中没截图,大家可以到原博客看) 一.所需的环境和软件:(以下是我们的环境,仅供参考) 1. 操作系统:Window