本文介绍如何使用ARMS前端监控开始监控钉钉小程序,以及相关的通用配置、API方法和进阶场景。
背景信息
关于钉钉小程序的背景信息,请参见钉钉小程序。
操作步骤
操作步骤包括引入npm包并初始化、上报和设置安全域名。
- 引入npm包并初始化。
- 在钉钉小程序的项目中引入alife-logger npm包,以便使用该模块来上报日志。
npm install alife-logger
- 将以下内容添加至/utils目录下的monitor.js文件中以完成初始化。说明 您可以自定义JS文件的名称和存放位置。
import EAppLogger from 'alife-logger/eapp'; const Monitor = EAppLogger.init({ pid: 'xxx', region: "cn", // 指定应用部署的地域:中国设为cn,海外地区靠近新加坡的设为sg,靠近美国的设为us。 }); export default Monitor;
说明 关于参数的详细配置,请参见通用SDK配置项。
- 在钉钉小程序的项目中引入alife-logger npm包,以便使用该模块来上报日志。
- 使用以下方法静默采集和上报PV、Error、API、性能及Health数据。
- 在app.js中,使用
Monitor.hookApp(options)
方法静默捕获Error类日志。其中的options即为App层相应的Object配置。import Monitor from '/util/monitor'; App(Monitor.hookApp({ onError(err) { console.log('进入onError:', err); }, onLaunch() { console.log('进入onLaunch'); }, onShow(options) { }, onHide() { } }));
- 在Page的JS文件中通过
Monitor.hookPage(options)
方法静默上报API请求、PV、Health数据。import Monitor from '/util/monitor'; // 使用hookPage后,生命周期的API会自动打点。 Page(Monitor.hookPage({ data: {}, onLoad(query) { }, onReady() { // 页面加载完成。 }, onShow() { }, onLoad(query) { }, onHide() { }, onUnload() { } }));
- 在app.js中,使用
- 设置安全域名。
- 如果region设为
cn
,则将arms-retcode.aliyuncs.com添加到HTTP安全域名。 - 如果region设为
sg
,则将arms-retcode-sg.aliyuncs.com添加到HTTP安全域名。 - 如果region设为
us
,则将arms-retcode-us.aliyuncs.com添加到HTTP安全域名。
- 如果region设为
API方法:静默打点基础API
方法 | 参数 | 备注 | 示例使用场景 |
hookApp | {} | 请传入原有的App参数。 | 在App的生命周期中自动打点。 |
hookPage | {} | 请传入原有的Page参数。 | 在Page的生命周期中自动打点。 |
API方法:其他设置API
方法 | 参数 | 备注 |
setCommonInfo | {[key: string]: string;} | 设置日志基础字段,可用于灰度发布等场景。 |
setConfig | {[key: string]: string;} | 设置config字段,具体操作,请参见SDK参考。 |
pageShow | {} | 触发Page Show,发送PV数据。 |
pageHide | {} | 触发Page Hide,发送Health数据。 |
error | String/Object | 错误日志打点。 |
api | 请参见前端接口说明 | API类日志上报。 |
sum/avg | String | 自定义求和、求均值日志上报。 |
高级使用方法
当基础使用方法无法满足需求时,请参见以下进阶场景。
手动上报API相关信息(不采用静默上报方式)
- 将disableHook设为
true
,不静默上报dd.httpRequest请求的日志。 - 手动调用
api()
方法上报API相关信息。
- 将disableHook设为
取消静默上报并改为手动打点
在App和Page对应的JS文件中不再使用
hookApp()
、hookPage()
方法。如需发送当前页面的PV数据,则在Page的
onShow()
方法下调用pageShow()
方法。说明 请勿与hookPage()
方法同时使用此方法,否则会造成PV类日志重复上报。import Monitor from '/util/monitor'; Page({ onShow: function() { Monitor.pageShow(); } })
如需发送当前页面的Health类数据,统计当前页面的健康度和页面停留时间,则在Page的
onHide()
和onUnload()
方法下调用pageHide()
方法。说明 请勿与hookPage()
方法同时使用此方法,否则会造成日志重复上报。import Monitor from '/util/monitor'; Page({ onHide: function() { Monitor.pageHide(); }, onUnload: function() { Monitor.pageHide(); } ... })
通用SDK配置项
ARMS前端监控提供一系列SDK配置项,让您能够通过设置参数来满足额外需求。以下是适用于本文场景的通用配置项。
pid | String | 项目唯一ID,由ARMS在创建站点时自动生成。 | 是 | 无 |
uid | String | 用户ID,用于标识访问用户,可手动配置,用于根据用户ID检索。如果不配置,则由SDK随机自动生成且每半年更新一次。 | 否 | 由SDK自动生成 |
tag | String | 传入的标记,每条日志都会携带该标记。 | 否 | 无 |
release | String | 应用版本号。建议您配置,便于查看不同版本的上报信息。 | 否 |
|
environment | String | 环境字段,取值为:prod、gray、pre、daily和local,其中:
| 否 |
|
sample | Integer | 日志采样配置,值为1~100的整数。对性能日志和成功API日志按照 | 否 |
|
behavior | Boolean | 是否为了便于排查错误而记录报错的用户行为。 | 否 |
|
enableLinkTrace | Boolean | 进行前后端链路追踪,请参见使用前后端链路追踪诊断API错误原因。 | 否 |
|
ARMS前端监控还提供了更多SDK配置项,可满足进一步的需求。更多信息,请参见SDK参考。