-
Notifications
You must be signed in to change notification settings - Fork 424
移动性能监控 SDK 详细集成文档
一. Gradle配置
- 在 Project 的 build.gradle 文件中添加ArgusAPM的相关配置,示例如下:
在项目根目录的 build.gradle(注意:不是 app/build.gradle) 中添加以下配置:
buildscript {
repositories {
jcenter()
}
dependencies {
classpath 'com.android.tools.build:gradle:2.2.3'
classpath 'com.qihoo360.argusapm:argus-apm-gradle-asm:3.0.1.1001'
}
}
allprojects {
repositories {
jcenter()
}
}
- 在app的build.gradle 文件中添加插件引用,示例如下:
apply plugin: 'argusapm'
//在android的配置代码块里面(为了兼容Android6.0系统):
android {
useLibrary ‘org.apache.http.legacy‘
}
- 特殊配置
如果接入过程一切正常,可忽略该部分。
ArgusAPM的部分监控代码,是通过Gradle的Transform API,在编译期织入的,由于我们在开发中可能会引入各种lib库,而这些库可能会因各种各样的原因,不允许我们织入,具体表现就是,编译期报如下错:
can't determine superclass of missing type**
when weaving type**
when weaving classes
when weaving
when batch building BuildConfig[null] #Files=0 AopXmls=#0[Xlint:cantFindType]
如果您在编译期遇到如上问题,则需要找到对应报错的库,把这个库过滤掉,具体过滤方式:
1)在主项目build.gradle同级目录下,新增argusapm.gradle文件,内容如下:
apply plugin: 'argusapm'
argusApmAjxConfig
{
exclude 'com.qihoo360.xxx' // 跳过 com.qihoo360.xxx包下的所有文件
excludeJar 'libammsdk' // 跳过 libammsdk.jar
}
2)将app的build.gradle中的apply plugin: ‘argusapm’ 修改为apply from: ‘argusapm.gradle’。
二. AndroidManifest.xml配置
a. 权限相关
<!--需要申请如下权限-->
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.BATTERY_STATS" />
<uses-permission android:name="android.permission.READ_PHONE_STATE" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
b. 组件使用 需要在AndroidManifest.xml里添加如下组件声明:
<provider
android:name="com.argusapm.android.core.storage.ApmProvider"
android:authorities="{当前应用的applicationId}.apm.storage"
android:exported="false" />
**三. 代码部分(重要类介绍及使用方法)**
- Config.ConfigBuilder配置项方法说明:
方法 | 说明 |
---|---|
setAppContext | 设置ArgusAPM所需要的上下文环境(必选) |
setAppName | 设置APP名称(英文,必选) |
setAppVersion | 设置APP版本号(必选) |
setApmid | 设置ArgusAPM分配给应用的唯一标识appkey(必选,由移动性能监控服务提供,不可随意设置) |
setRuleRequest | 设置云规则请求 |
setUpload | 设置ArgusAPM采集到的数据上传 |
setEnabled | 设置ArgusAPM在当前进程是否启用某个收集模块的逻辑,用于多进程场景(可选),参数见flag说明 |
setDisabled | 设置ArgusAPM在当前进程是否禁用某个收集模块的逻辑,用于多进程场景(可选),参数见flag说明 |
build | 最终生成Config对象 |
- Client类的主要方法(启动移动性能监控服务):
方法 | 说明 |
---|---|
attach | 使用Config.ConfigBuilder初始化ArgusAPM(建议在Application的attachBaseContext里调用) |
isDebugOpen | 是否开启debug模式,,如果开启的话,则会有悬浮窗功能 |
startWork | 启用ArgusAPM开始工作 |
四. 一个简单的SDK初始化代码
在项目的Application的attachBaseContext里调用如下代码即可
// 注:根据实际情况,来选择主进程
// 如果您有常驻进程,则主进程是常驻进程
// 如果您是单进程模型,则主进程是UI进程
boolean isMainProcess = TextUtils.equals(getPackageName(), getCurrentProcessName());
Config.ConfigBuilder builder = new Config.ConfigBuilder()
.setAppContext(this)
.setRuleRequest(new RuleSyncRequest())
.setUpload(new CollectDataSyncUpload())
.setAppName("apm_demo")
.setAppVersion("0.0.1")
.setApmid("apm_demo");
//单进程应用可忽略builder.setDisabled相关配置。
if(!isMainProcess) {
//除了“主进程”,其他进程不需要进行数据上报、清理等逻辑。“主进程”通常为常驻进行,如果无常驻进程,即为UI进程。
builder.setDisabled(ApmTask.FLAG_DATA_CLEAN) //只有主进程才清理数据
.setDisabled(ApmTask.FLAG_CLOUD_UPDATE)//只有主进程才执行云控
.setDisabled(ApmTask.FLAG_DATA_UPLOAD)//只有主进程才执行数据上报
.setDisabled(ApmTask.FLAG_COLLECT_ANR)//只有主进程才收集ANR
.setDisabled(ApmTask.FLAG_COLLECT_FILE_INFO) //只有主进程才收集文件信息
.setDisabled(ApmTask.FLAG_COLLECT_CPU);//只有主进程才收集CPU数据
}
//builder.setEnabled(ApmTask.FLAG_COLLECT_ACTIVITY_AOP); //activity采用aop方案时打开,默认关闭即可。
//builder.setEnabled(ApmTask.FLAG_LOCAL_DEBUG); //是否读取本地配置,默认关闭即可。
Client.attach(builder.build());
// Client.isDebugOpen(true, getPackageName());// 是否展示debug模式悬浮窗。根据项目需求添加
Client.startWork();
注意:
apmid(appkey)名称必须保证唯一性,由Argus APM统一分配,请勿随意填写。
申请地址:现已停止对外接入服务,详情请查看首页公告!
如此,移动性能监控 SDK就接入完成,更多技巧请参考详细接入文档。
五. 接入成功日志输出
接入完毕,运行应用,如果看到以下log,说明接入成功:
六. 混淆相关
无需任何混淆配置,因为ArgusAPM的AAR自带Proguard文件,直接接入ArgusAPM-SDK即可生效。