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

100 篇文章 1 订阅
100 篇文章 2 订阅

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

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值