背景

对于信息系统服务,一般我们的重点监控对象都是核心的后端服务,通常会采用一些主流的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 虚拟设备,同时方便开发与调试。

参考

https://at.umtrack.com/XHHrme


If you have any questions or any bugs are found, please feel free to contact me.

Your comments and suggestions are welcome!

Logo

讨论HarmonyOS开发技术,专注于API与组件、DevEco Studio、测试、元服务和应用上架分发等。

更多推荐