文章目录
• 一、前言
• 二、快速集成
o 2.1 账号注册
o 2.2 创建应用
o 2.3 Demo下载
o 2.4 Demo导入
o 2.5 Demo试跑
• 三、极致体验
o 3.1 第一个App崩溃
o 3.2 查看后台崩溃信息(延时1分钟+)
o 3.3 错误处理
o 3.4 告警设置
o 3.5 企业微信机器人
o 3.6 告警触发
• 四、一点小建议
o 4.1 错误明细中缺乏App版本
o 4.2 错误处理的逻辑流程
一、前言
之前一直是用腾讯的bugly
目前受邀推荐使用友盟+U-APM,那就让我们来尝试体验一下
二、快速集成
2.1 账号注册
友盟+注册
注册很快,没有繁琐的步骤和多余的信息填写,点赞
2.2 创建应用
应用性能监控平台U-APM
2.3 Demo下载
为了快速体验,我们跳过SDK集成这一步,直接用官方提供的Demo。
SDK集成也很方便,直接看官方文档即可:Android SDK集成流程
Demo下载:MultiFunctionAndroidDemo:友盟多功能Android Demo
2.4 Demo导入
导入工程File->New->Import Porject
期间有遇到一个问题,如果大家也同样遇到这个问题可以参考博文:Android Studio Failed to open zip file的解决办法
2.5 Demo试跑
修改preInit(Context context,String appkey,String channel)后,即可运行Demo
// SDK预初始化函数
// preInit预初始化函数耗时极少,不会影响App首次冷启动用户体验
public static void preInit(Context context,String appkey,String channel)
preInit()在App.java里面调用,传入自己的appkey即可。
appkey在如下图中复制。
Demo跑起来后,再去后台看看,就会发现应用的状态变成:已集成
三、极致体验
3.1 第一个App崩溃
• 有点意外, 第一个崩溃信息出来的有点快。
• 首页->点击统计UApp->点击程序崩溃
3.2 查看后台崩溃信息(延时1分钟+)
• 这时候就要赶紧看下后台,有没有错误信息上报
• 一直刷新后台,同时对比实时时间,大概延时1分10秒左右,后台才显示出错误信息。与腾讯bugly对比略微好点,半斤八两吧
• 不过,错误信息倒是给的详细,直接找到com.umeng.soexample.analytics.UappActivity的第94行
• 认真一看,很明显的错误,"123"的字符串长度只有3,无法索引到10
3.3 错误处理
• 把未修复改成已修复
• 首先,故意不修复代码,再制造一次程序崩溃
o 处理状态不变,还是已修复
• 其次,修改App版本versionCode改成2,versionName改成1.0.1,其他不变,再制造一次程序崩溃
o 处理状态依旧不变,还是已修复。
o 不过版本范围变了1.0 ~ 1.0.1。这就有点参差了,对此我就有点意见了,详情见后文第四章节。
3.4 告警设置
• 通过错误列表的告警入口进来
• 新建告警计划
o 告警名称
o 触发条件:>3次
o 生效应用版本:全部
o 触达方式:邮箱、企业微信
3.5 企业微信机器人
• 添加一个群聊
• 添加群机器人
• 得到该机器人的Webhook
3.6 告警触发
• 告警设置成功后,就开始触发告警
• 点了好几次都没反应,奇奇怪怪
• 没关系,有点耐心,等~
• 终于被我等到了~
• 很明显看出来,告警触发是每小时一次的
• 基本都在每小时的07分左右推送
四、一点小建议
4.1 错误明细中缺乏App版本
• App版本号在错误列表中有体现,挺好的
• 但是在错误明细中没有体现,相反还多出一个SDK版本号,容易混淆
4.2 错误处理的逻辑流程
错误处理的逻辑流程可以优化成如下:
• 在崩溃分析->错误列表->处理状态在勾选已修复的时候,选择在XX.XX.XX版本修复
• 后续如果版本大于 XX.XX.XX版本时,还有同样的错误上报,则把处理状态自动修改成修复失败
• 增加一个处理流程记录,详细记录这个bug在XX时间被XX人在XX版本修复,然后在XX版本又复发……
按照这个逻辑修改后,处理状态是动态的,增加了更多的信息。
比起目前,一旦手动修改了处理状态后,其状态一直不变,是不是强多了~
作者:康玮剑
1、多年嵌入式软件开发经验;
2、同样擅长Android开发和微信小程序开发;
3、做过大厂的系统工程师,当过小厂的嵌入式主管,现在是个创业公司的软件经理;
4、对IoT物联网开发有自己的见解,业余时间喜欢沉淀、整理与分享输出自身的技术知识。