背景
对于信息系统服务,一般我们的重点监控对象都是核心的后端服务,通常会采用一些主流的APM(Application Performance Management)框架进行监控、告警、分析。那么对于移动端的APP、小程序的运行时状态如何进行实时监控与分析呢?经过这次CSDN官方的推荐,友盟+提供的APM服务可以实现我们的这一目标,下面我们就尝试集成体验下友盟+提供的这款APM服务。
由于我们的 APP是基于华为的鸿蒙操作系统进行开发,而注册友盟后,发现当前对于移动端APP,友盟官方提供了 Android与 iOS移动端操作系统的集成与接入,尚未提供对华为鸿蒙操作系统的支持(不过后来看到在上报的异常处可按照 只看鸿蒙设备 进行筛选:指发生错误/异常的设备为HarmonyOS,但尚未支持HarmonyOS系统级别错误)。
体验流程
本着体验下友盟+提供的APM服务的目的,这里使用一个基于 Android的 Hello World示例:
- 首先按照官方文档完成移动端 APP与友盟 SDK的集成;
- 然后在示例中抛出一些异常( OOM等);
- 最后在友盟的移动端应用监控首页可以看到我们应用上报的异常信息。
使用IDEA创建Android项目
当然,集成之前需要先搭建一个极简的 Android的 Hello World应用。
由于我之前并没有Android的移动端开发经验,当然也没有对应的开发环境,那么这里直接使用IDEA创建一个Android应用。
安装AndroidSDK
在IDEA中创建一个Android项目,先安装Android的SDK,我这里使用默认位置直接安装。
创建一个空的Activity
创建一个虚拟设备
虚拟设备安装完成
集成友盟+APM的SDK
友盟+的APM的SDK集成过程也是相当丝滑,参考官方文档推荐的 maven 线上接入 SDK,只需三步:1.创建应用;2.添加SDK依赖;3.初始化信息上报。
1. 创建应用
2. 添加SDK依赖
3. 初始化信息上报
涉及到的配置与代码如下:
dependencies {
implementation fileTree(dir: 'libs', include: ['*.jar'])
implementation 'androidx.appcompat:appcompat:1.0.2'
implementation 'androidx.constraintlayout:constraintlayout:1.1.3'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'androidx.test:runner:1.1.1'
androidTestImplementation 'androidx.test.espresso:espresso-core:3.1.1'
// 友盟基础组件库(所有友盟业务SDK都依赖基础组件库)
implementation "com.umeng.umsdk:common:9.4.2" // 版本号(必选))
implementation "com.umeng.umsdk:asms:1.4.1" // asms包依赖(必选)
implementation "com.umeng.umsdk:apm:1.4.2" // U-APM产品包依赖(必选)
}
// umeng
buildscript {
repositories {
google()
jcenter()
maven { url 'https://repo1.maven.org/maven2/' }
}
dependencies {
classpath 'com.android.tools.build:gradle:3.4.0'
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
allprojects {
repositories {
google()
jcenter()
maven { url 'https://repo1.maven.org/maven2/' }
}
}
// 通用初始化
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
// umeng
UMConfigure.setLogEnabled(true);
UMConfigure.init(this, "613b2a85314602341a0df802", "csdn", UMConfigure.DEVICE_TYPE_PHONE, "");
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
}
}
最终配置
启动后报错:无法联网
由于项目启动后,友盟+的SDK会进行信息上报,这时需要联网,而默认创建项目后没有联网权限,因此会出现一个报错信息。
为APP配置联网权限
集成成功效果
模拟各类异常
为了体验友盟+APM服务基本的监控功能,我们这里模拟一些异常,然后看这些异常信息是否可以上报至APM平台。
- 普通的运行时异常:ArithmeticException/NullPointerException
- 栈溢出异常:StackOverflowError
- 内存溢出异常:. OutOfMemoryError
除0异常:ArithmeticException
// 发送异常按钮的点击事件:模拟除零异常
public void exception(View view) {
try {
int value = 8 / 0;
} catch (Exception e) {
UMCrash.generateCustomLog(e, "5001");
}
}
栈溢出异常:StackOverflowError
// 发送SoF异常按钮的点击事件:模拟栈溢出异常
public void exceptionStackOverFlow(View view) {
try {
exceptionStackOverFlow(view);
} catch (Exception e) {
UMCrash.generateCustomLog(e, "5002");
}
}
内存溢出异常:. OutOfMemoryError
// 发送OOM异常按钮的点击事件:模拟内存溢出异常,当然OOM还有其他类型,这里以堆溢出为例进行演示
public void exceptionOutOfMemory(View view) {
try {
List<byte[]> list = new ArrayList<>();
while (true) {
list.add(new byte[1024 * 1024]);
}
} catch (Exception e) {
UMCrash.generateCustomLog(e, "5003");
}
}
异常自动上报
除0异常上报:ArithmeticException
栈溢出异常上报:StackOverflowError
内存溢出异常上报:OutOfMemoryError
异常告警
支持邮箱、钉钉、企业微信、飞书以及Webhook方式推送。
统计分析
可对不同类型的异常进行多维度的统计与分析,大家可以继续探索挖掘。
总结
通过以上流程,我们测试了移动端APP异常数据上报与统计功能,这个其实有点类似我们物联网设备数据采集、传输与分析的流程,而且整个集成的流程也比较顺畅,简单几步就给我们的APP做了做了一个服务远程监控端。
后面我们APP上线后,友盟+这款APM服务将是我们线上移动端应用监控的一把利器。另外,期待友盟+官方可以提供鸿蒙操作系统的接入,以便直接支持Huawei DevEco Studio中的基于HarmonyOS虚拟设备,同时方便开发与调试。
作者:牛晓青
1. 曾参与脑电信号模式识别研究,教学软件、分布式互联网项目以及大型物联网平台的设计开发等工作。
2. 有4年团队管理经验,曾从0到1搭建技术团队,从最初的1人到现在的25人。负责的项目已落地多个城市。
3. 负责20+人团队管理、日常工作任务分配、工作进度跟踪、工作成果汇报、团队内部分享。精进管理,取得PMP项目管理专业人士资格认证。
4. 负责公司业务平台架构设计,方案编写,资金申报,研发部团队建设,项目验收培训、对外宣讲等工作。持续输出,获得CSDN博客专家认证。