【鸿蒙实战开发】基于HiAppEvent能力的应用崩溃监控上报

102 篇文章 0 订阅
102 篇文章 0 订阅

HiAppEvent介绍:

HiAppEvent的接口设计,由系统决定回调的时机。使用这种机制,可以获取的应用崩溃事件结构化日志。HiAppEvent运营&运维事件软件模块,用于连接APP开发者、APM上传模块、HiView故障维测服务。支撑应用开发者完成运营和运维的数据分析工作。

主要通过如下措施支持开发者快速完成APP线上的运营和运维功能:

⦁ 措施1:开放系统事件订阅API,可以订阅到系统检测到APP相关事件,包括崩溃、卡死等。

⦁ 措施2:开放自定义事件API,开发者可以本地记录事件、本地记录用户属性。

⦁ 措施3:开放故障日志,开发者订阅系统事件后同步可获取相关故障的日志。

⦁ 措施4:开放数据处理者API,开发者可以选择华为提供的分析服务。

事件定义说明事件领域(domain)用于标识事件的领域,建议设置为业务模块名称,以便于区分不同的业务模块。事件名称(name)用于指定事件的名称,建议设置为具体的业务名称,以便于描述实际的业务意义。

事件类型(eventType)用于指定事件的类型,支持以下四种类型事件。

⦁ 行为事件:用于记录用户日常操作行为的事件,例如按钮点击、界面跳转等行为。

⦁ 故障事件:用于定位和分析应用故障的事件,例如界面卡顿、掉网掉话等异常。

⦁ 统计事件:用于统计和度量应用关键行为的事件,例如对使用时长、访问数等的统计。

⦁ 安全事件:用于记录涉及应用安全行为的事件,例如密码修改、用户授权等行为。

事件参数(params)用于指定事件的参数,每个事件可以包含一组参数,建议设置为事件属性或事件发生上下文信息,以便于描述事件的详细信息。

使用hiAppEvent进行崩溃的监听,在应用崩溃之后,用户可以通过再次进入应用,进行崩溃信息的处理。

相同能力对比:FaultLogger。

FaultLogger和HiAppEvent如何选择,区别是什么。

(1)FaultLogger是日志查询功能,开发者可以主动查询近期发生的故障日志。

(2)HiAppEvent是事件记录和监听功能,开发者可以监听行为、故障、统计、安全事件。

功能场景描述及使用场景

场景一:应用崩溃监听。

在应用发生CPP_CRASH、JS_CRASH、APP_FREEZE后便于监听相应的崩溃信息进行处理。

核心代码解释

使用hiAppEvent进行崩溃的监听,在应用崩溃之后,用户可以通过再次进入应用,进行崩溃信息的处理。

代码逻辑:

⦁ 首先定义观察者addWatcher,以添加对应用事件的订阅。

⦁ 订阅崩溃事件。

核心代码如下:

添加应用崩溃事件观察者方法:

hiAppEvent.addWatcher({ 
  // 开发者可以自定义观察者名称,系统会使用名称来标识不同的观察者 
  name: "watcher2", 
  // 开发者可以订阅感兴趣的系统事件,此处是订阅了崩溃事件 
  appEventFilters: [ 
    { 
      domain: hiAppEvent.domain.OS, 
      names: [hiAppEvent.event.APP_CRASH,hiAppEvent.event.APP_FREEZE] 
    } 
  ], 
  // 开发者可以自行实现订阅实时回调函数,以便对订阅获取到的事件数据进行自定义处理 
  onReceive: (domain: string, appEventGroups: Array<hiAppEvent.AppEventGroup>) => { 
    hilog.info(0x0000, 'testTag', `HiAppEvent onReceive: domain=${domain}`); 
    for (const eventGroup of appEventGroups) { 
      // 开发者可以根据事件集合中的事件名称区分不同的系统事件 
      hilog.info(0x0000, 'testTag', `HiAppEvent eventName=${eventGroup.name}`); 
      for (const eventInfo of eventGroup.appEventInfos) { 
        // 开发者可以对事件集合中的事件数据进行自定义处理,此处是将事件数据打印在日志中 
        hilog.info(0x0000, 'testTag', `HiAppEvent eventInfo.domain=${eventInfo.domain}`); 
        hilog.info(0x0000, 'testTag', `HiAppEvent eventInfo.name=${eventInfo.name}`); 
        hilog.info(0x0000, 'testTag', `HiAppEvent eventInfo.eventType=${eventInfo.eventType}`); 
        // 开发者可以获取到崩溃事件发生的时间戳 
        hilog.info(0x0000, 'testTag', `HiAppEvent eventInfo.params.time=${eventInfo.params['time']}`); 
        // 开发者可以获取到崩溃事件发生的崩溃类型 
        hilog.info(0x0000, 'testTag', `HiAppEvent eventInfo.params.crash_type=${eventInfo.params['crash_type']}`); 
        // 开发者可以获取到崩溃应用的前后台状态 
        hilog.info(0x0000, 'testTag', `HiAppEvent eventInfo.params.foreground=${eventInfo.params['foreground']}`); 
        // 开发者可以获取到崩溃应用的版本信息 
        hilog.info(0x0000, 'testTag', `HiAppEvent eventInfo.params.bundle_version=${eventInfo.params['bundle_version']}`); 
        // 开发者可以获取到崩溃应用的包名 
        hilog.info(0x0000, 'testTag', `HiAppEvent eventInfo.params.bundle_name=${eventInfo.params['bundle_name']}`); 
        // 开发者可以获取到崩溃应用的进程id 
        hilog.info(0x0000, 'testTag', `HiAppEvent eventInfo.params.pid=${eventInfo.params['pid']}`); 
        hilog.info(0x0000, 'testTag', `HiAppEvent eventInfo.params.uid=${eventInfo.params['uid']}`); 
        hilog.info(0x0000, 'testTag', `HiAppEvent eventInfo.params.uuid=${eventInfo.params['uuid']}`); 
        // 开发者可以获取到崩溃事件发生的异常类型、异常原因和异常调用栈 
        hilog.info(0x0000, 'testTag', `HiAppEvent eventInfo.params.exception=${JSON.stringify(eventInfo.params['exception'])}`); 
        // 开发者可以获取到崩溃事件发生时日志信息 
        hilog.info(0x0000, 'testTag', `HiAppEvent eventInfo.params.hilog.size=${eventInfo.params['hilog'].length}`); 
        console.log("testTag" + eventGroup.name.toString()) 
 
        if(eventGroup.name.toString() === 'APP_FREEZE'){ 
          hilog.info(0x0000, 'testTag', `HiAppEvent eventInfo.params.event_handler.size=${eventInfo.params['event_handler'].length}`); 
          hilog.info(0x0000, 'testTag', `HiAppEvent eventInfo.params.event_handler_size_3s=${eventInfo.params['event_handler_size_3s']}`); 
          hilog.info(0x0000, 'testTag', `HiAppEvent eventInfo.params.event_handler_size_6s=${eventInfo.params['event_handler_size_6s']}`); 
          // 开发者可以获取到卡死事件发生时同步binder调用信息 
          hilog.info(0x0000, 'testTag', `HiAppEvent eventInfo.params.peer_binder.size=${eventInfo.params['peer_binder'].length}`); 
          // 开发者可以获取到卡死事件发生时全量线程调用栈 
          hilog.info(0x0000, 'testTag', `HiAppEvent eventInfo.params.threads.size=${eventInfo.params['threads'].length}`); 
          // 开发者可以获取到卡死事件发生时内存信息 
          hilog.info(0x0000, 'testTag', `HiAppEvent eventInfo.params.memory=${JSON.stringify(eventInfo.params['memory'])}`); 
        } 
      } 
    } 
  } 
});

崩溃模拟:

Button("app-Freeze").onClick(()=>{ 
  // 在按钮点击函数中构造一个freeze场景,触发应用卡死事件 
  setTimeout(() => { 
    while (true) {} 
  }, 1000) 
}) 
 
Button("js-Crash").onClick(()=>{ 
  // 在按钮点击函数中构造一个crash场景,触发应用崩溃事件 
  let result: object = JSON.parse(""); 
}) 
 
Button("Cpp-Crash").onClick(()=>{ 
  // 在按钮点击函数中构造一个crash场景,触发应用崩溃事件 
  hilog.info(0x0000, 'testTag', 'Test NAPI 2 + 3 = %{public}d', testNapi.add(2, 3)); 
})

场景二:基于HiAppEvent能力的应用崩溃监控上报

接入云侧服务:

//配置需要上传的事件 
let eventConfig: hiAppEvent.AppEventReportConfig = { 
  domain: 'button', 
  name: 'click', 
  isRealTime: true 
}; 
//配置要使用的华为云属性 
let processor: hiAppEvent.Processor = { 
  name: 'analytics_demo', 
  debugMode: true, 
  routeInfo: 'CN', 
  onStartReport: true, 
  onBackgroundReport: true, 
  periodReport: 10, 
  batchReport: 5, 
  userIds: ['testUserIdName'], 
  userProperties: ['testUserPropertyName'], 
  eventConfigs: [eventConfig] 
}; 
//添加数据处理者 
this.processorId = hiAppEvent.addProcessor(processor);

鸿蒙全栈开发全新学习指南

有很多小伙伴不知道学习哪些鸿蒙开发技术?不知道需要重点掌握哪些鸿蒙应用开发知识点?而且学习时频繁踩坑,最终浪费大量时间。所以要有一份实用的鸿蒙(HarmonyOS NEXT)学习路线与学习文档用来跟着学习是非常有必要的。

针对一些列因素,整理了一套纯血版鸿蒙(HarmonyOS Next)全栈开发技术的学习路线,包含了鸿蒙开发必掌握的核心知识要点,内容有(ArkTS、ArkUI开发组件、Stage模型、多端部署、分布式应用开发、WebGL、元服务、OpenHarmony多媒体技术、Napi组件、OpenHarmony内核、OpenHarmony驱动开发、系统定制移植等等)鸿蒙(HarmonyOS NEXT)技术知识点。

本路线共分为四个阶段

第一阶段:鸿蒙初中级开发必备技能

在这里插入图片描述

第二阶段:鸿蒙南北双向高工技能基础:gitee.com/MNxiaona/733GH

第三阶段:应用开发中高级就业技术

第四阶段:全网首发-工业级南向设备开发就业技术:gitee.com/MNxiaona/733GH

《鸿蒙 (Harmony OS)开发学习手册》(共计892页)

如何快速入门?

1.基本概念
2.构建第一个ArkTS应用
3.……

开发基础知识:gitee.com/MNxiaona/733GH

1.应用基础知识
2.配置文件
3.应用数据管理
4.应用安全管理
5.应用隐私保护
6.三方应用调用管控机制
7.资源分类与访问
8.学习ArkTS语言
9.……

基于ArkTS 开发

1.Ability开发
2.UI开发
3.公共事件与通知
4.窗口管理
5.媒体
6.安全
7.网络与链接
8.电话服务
9.数据管理
10.后台任务(Background Task)管理
11.设备管理
12.设备使用信息统计
13.DFX
14.国际化开发
15.折叠屏系列
16.……

鸿蒙开发面试真题(含参考答案):gitee.com/MNxiaona/733GH

鸿蒙入门教学视频:

美团APP实战开发教学:gitee.com/MNxiaona/733GH

写在最后

  • 如果你觉得这篇内容对你还蛮有帮助,我想邀请你帮我三个小忙:
  • 点赞,转发,有你们的 『点赞和评论』,才是我创造的动力。
  • 关注小编,同时可以期待后续文章ing🚀,不定期分享原创知识。
  • 想要获取更多完整鸿蒙最新学习资源,请移步前往小编:gitee.com/MNxiaona/733GH

  • 14
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值