问题场景:
用户需要在另一个进程里收集用户产生的日志及crash文件,并上报给自己的服务器。或者是在应用发生CPP_CRASH、JS_CRASH、APP_FREEZE后便于监听相应的崩溃信息进行处理。
问题场景:
用户需要在另一个进程里收集用户产生的日志及crash文件,并上报给自己的服务器。或者是在应用发生CPP_CRASH、JS_CRASH、APP_FREEZE后便于监听相应的崩溃信息进行处理。
1 回答1.1k 阅读✓ 已解决
1 回答1.3k 阅读
1 回答1.2k 阅读
1 回答1.1k 阅读
1 回答1.1k 阅读
1 回答970 阅读
1 回答943 阅读
解决方案 :
HiAppEvent类似ios metrickit的接口设计,由系统决定回调的时机。faultlog能查询的,hiappevent都将提供回调。使用这种机制,可以获取的应用奔溃事件结构化日志。
HiAppEvent运营&运维事件软件模块,用于连接APP开发者、APM上传模块、HiView故障维测服务。支撑应用开发者完成运营和运维的数据分析工作。
主要通过如下措施支持开发者快速完成APP线上的运营和运维功能。
措施1:开放系统事件订阅API,可以订阅到系统检测到APP相关事件,包括崩溃、卡死等。
措施2:开放自定义事件API,开发者可以本地记录事件、本地记录用户属性。
措施3:开放故障日志,开发者订阅系统事件后同步可获取相关故障的日志。
措施4:开放数据处理者API,开发者可以选择华为提供的分析服务。
事件定义说明事件领域(domain)用于标识事件的领域,建议设置为业务模块名称,以便于区分不同的业务模块。事件名称(name)用于指定事件的名称,建议设置为具体的业务名称,以便于描述实际的业务意义。事件类型(eventType)
用于指定事件的类型,支持以下四种类型事件:
·
事件参数(params)用于指定事件的参数,每个事件可以包含一组参数,建议设置为事件属性或事件发生上下文信息,以便于描述事件的详细信息。
使用hiAppEvent进行崩溃的监听,在应用崩溃之后,用户可以通过在次进入应用,进行崩溃信息的处理。在应用再次启动时会有个几十秒的等待时间处理。
核心代码如下:
添加应用崩溃事件观察者方法,通过以下接口订阅系统采集的故障事件:
接入华为提供的云侧服务:
崩溃模拟:
获取故障日志:
系统检测到故障并生成的日志,会存储在应用沙箱内的log目录,具体路径为/data/storage/el2/log,当前该目录已经创建,故障日志的生成正在设计和开发,开发者可以在应用内获取到事件和日志。
实现效果: