0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

应用可靠性与性能不给力?HarmonyOS HiViewDFX了解一下

HarmonyOS开发者 来源:未知 2023-02-04 12:50 次阅读
作为基础软件服务子系统的HarmonyOS HiViewDFX(以下简称HiViewDFX)框架,是HarmonyOS的公共基础设施。包括日志、事件、跟踪、故障管理及观测剖析五大部分,同时也提供了故障检测、定位和性能观测剖析的开发套件,以及将端侧数据直接对接云侧大数据质量分析平台和IDE(Integrated Development Environment, 集成开发环境)调试调优工具。为应对应用开发难题,HiViewDFX提供了高保障能力。

HarmonyOSHiViewDFX框架图


HiViewDFX介绍

一般地,捕获异常信号需要自行增加捕获异常的机制,通过信号来感知异常及采集对应的异常日志,但是往往这类信息无法有效的与系统信息关联。

HiViewDFX为应用开发者提供了具有轻量级故障检测、精准的故障定位日志以及快速恢复功能的开发套件,能够迅速提高应用的可靠性。
如下图所示,在HarmonyOS系统中首先内置崩溃、泄漏、卡死等轻量级故障检测器,用来记录应用在系统侧的异常状态。
其次,在应用程序框架内及运行时增加了异常捕获能力,使得系统和应用能够分层检测和记录异常信息,通过开放查询、订阅、恢复三个API(Application Programming Interface, 应用程序编程接口)提供给开发者。

HarmonyOS应用异常处理框架图

在应用崩溃和卡死的时候,HiViewDFX提供的精准日志定位功能能够详细地记录异常发生时的日志。
HiViewDFX 提供了对应的应用异常日志查询接口,将JS_CRASH, CPP_CRASH, APP_FREEZE这三类故障日志提供给开发者,并且是结构化的日志信息,开发者可以从反馈的信息中快速获取到故障的相关信息。
为给用户提供更佳的体验,在日志信息反馈异常数据的基础上,HiViewDFX提供了应用快速恢复的框架(如下图),当系统感知到JS_CRASH, CPP_CRASH, APP_FREEZE, KILL等故障之后,能快速通知应用,应用将之前的状态进行保存,而后系统会自动拉起应用,然后恢复到故障前的原界面。

应用恢复框架图


HIViewDFX相关工具介绍

HiViewDFX的工具入口---Insight,是DevEco Studio中的插件,拥有众多系统能力支撑,如图所示,有调试连接器、HiTrace、HiPerf 以及HiProfiler 框架。
HiViewDFX提供的系统能力包含日志、事件、分布式跟踪、故障等。

HiViewDFX调试调优架构图

接下来,就让我们一起了解下HiViewDFX提供的部分工具吧!
1)调试连接器
如下图所示,调试连接器是连接上位机和下位机的通道,通常用做嵌入式开发,常用的连接工具,比如,基于串口或者网口的Telnet、SSH等。
HarmonyOS面向不同形态的设备时,这些设备可能不具备网口或者USB端口,只有一个串口,要支持这个,串口上需要具备Shell和文件IO等功能。有了调试连接器作为中转,就可以让开发者使用的IDE和其他工具脚本无需面临硬件的复杂性,更好的关注调试和调优本身。

调试连接器原理示意图

2)HiTrace
如下图所示,HiTrace工具用于追踪进程轨迹,进行程序性能分析,支持内核FTrace预置埋点和用户态打点。
在性能分析中,Trace是最常用的方式,可以说Trace就是性能的日志,把Trace按照模块分门别类,这就是Trace的Tag。例如,Sched是操作系统内核的调度信息打点;Ability是Ability模块在用户态的关键生命周期打点。
假设定位某应用掉帧的问题,在分析时,打开Graphic、Ability、Sched等tag点,可以在Insight里面分析应用在送显、图形模块绘制相关的耗时。

HiTrace工具原理示意图

3)HiPerf
如下图所示,HiPerf是为开发者提供的采样调优分析工具,通过采样的方式,可以采集CPU PMU、Tracepoints以及程序热点函数信息,并且和Insight联动,提供离线和实时分析的能力。
HiPerf采集定位过程中会遇到一个难点:使用跨编程语言,在程序运行时,可能会存在一些跨语言的调用。例如,从JS调用NAPI到C++接口等。
因为是抽样的调用栈采集,如果只采集其中一种语言的调用栈会导致两个语言之间的耗时数据无法同步,从而产生冲突,影响性能问题的度量和定位,所以在调用栈采集的时候进行缝合。
HiPerf工具原理示意图
如下图所示,这段JS代码调用了三个内存相关的数据获取接口,均是NAPI实现的NATIVE接口。
在HiPerf中,首先采集NAPI调用JS的调用栈信息,当采集到一个C++的调用栈时,此时栈顶是函数NativeFunctionCallBack()的NAPI回调,则这个NATIVE调用栈就可以和前一次采集到的JS调用栈合并,最终拼接出一个完整的调用栈。

NAPI调用中JS-CPP栈缝合示意图

除了上述系统内置的分析点,开发者也可以通过HiTrace接口增加自定义的性能分析打点。
如下列代码所示,HiTraceMeter的接口比较简单,找到一段流程的开始和结束,加上Trace打点,就能在Insight中看到Start-End的耗时。
// API
declare namespace hiTraceMeter {
// Async trace
function startTrace(name: string, taskId: number, exceptedTime?: number): void;
function finishTrace(name: string, taskId: number): void;


// Counter trace
function traceByValue(name: string, count: number): void;
}


//example
onWindowStageCreate(windowStage) {
...
hiTraceMeter.startTrace('getMainWindow');
windowStage.getMainWindow().then((win) => {
Appstorage.SetOrCreate(Constants.MAIN_WINDOW, win);
hiTraceMeter.finishTrace('getMainWindow');
...
});
...
}

HiTrace API介绍及开发样例图(左右滑动)

4)HiProfiler
HiProfiler 框架是基于HiViewDFX基础能力构建的一个插件集,可以为Insight提供调优数据采集。
该组件整体分为PC端和设备端两部分。
PC端最终作为DevEco Studio的插件进行发布,内部主要包括分为UI绘制、设备管理、进程管理、插件管理、数据导入、数据存储、 数据分析、Session管理、配置管理等模块。
设备端主要包括命令行工具、服务进程、插件集合、应用程序组件等模块。
设备端提供了插件扩展能力,对外提供了插件接口,基于该扩展能力可以按需定义自己的能力,并集成到框架中。
HiProfiler框架

如何查询内存信息

操作系统对内存是分级定义的,从物理地址空间到虚拟地址空间,再分为用户态和内核态。应用内存调优分析的时候,还需要分解到虚拟地址、Ark JS的内存、NATIVE的内存、字体图标等资源、So的映射、线程栈等,这些都属于内存观测的范围。
HiViewDFX提供了HiDumper工具,作用是系统信息查询,它提供了系统版本、CPU占用率、内存以及Sa信息,开发者可以使用HiDumper来分析应用的内存(如下图)。
开发者分析内存比较关注的是Ark JS Heap以及NATIVE Heap、Pss、Dirty这些指标,如果程序有内存泄漏或者一般的内存膨胀的问题,可以看到这些值会不断变大。

HiDumper查看内存信息示意图

如果应用要在程序中监控内存,可以使用这组HiDebug接口(如下列代码所示),前三个接口是NATIVE内存分配器的统计信息,可以获取NATIVE分配器的总大小、分配大小和可用大小,后三个接口是从系统Smaps获取的统计信息,注意这两个信息不是一个维度上的,不能做数据的等同,在使用场景上也有差异。
// API
declarenamespacehidebug{
functiongetNativeHeapSize():bigint;
function getNativeHeapAllocatedSize(): bigint;
functiongetNativeHeapFreeSize():bigint;
functiongetPss():bigint;
functiongetSharedDirty():bigint;
functiongetPrivateDirty():bigint;
}

HiDebug接口示意图(左右滑动)

分配器的信息经常用于统计程序中对Native内存的分配情况,不代表这些内存实际被使用,这部分内存是开发者可以控制且可以进行优化的。
而系统Smaps统计信息,常用于程序感知自身内存的实际占用大小,这个大小经常受到分配器延迟释放、系统延迟回收、Copy-on-write、分配器MetaData额外损耗等,造成统计出来的内存信息和分配器控制的内存不完全等同,往往不能作为内存优化的直接依据,而是作为内存压力统计的依据。

如何进行内存调优分析

我们通过信息查询得知了内存的大小信息,那么如何进行内存分析呢?

如下图所示,右侧部分是开发者使用Insight进行分析的样例。
首先分析泳道图上的内存曲线,得到三类数据,JS、Native和虚拟内存,它们采集的分配信息基本都比较相似。例如,图中分配信息部分,名字和调用栈,是区分一块内存的重要信息,地址和大小是一块内存的基本信息。引用关系可以帮助我们建立内存之间的关系树,帮助我们更快找到内存的引入点。分配时间则可以帮助开发者了解哪些内存会长时间存留,长时间存留的内存是需要重点关注的。

内存分析数据采集原理图

另外,虽然虚拟内存在64位上可能不是一个痛点问题,但是在32位程序上经常会导致问题。32位程序的地址空间只有4GB,如果是32位内核,那么用户态一般情况只有3GB地址空间,这种情况下开发者需要关注虚拟内存的使用情况,HarmonyOS的做法是在Mmap的地方进行Hook,拿到分配的调用栈,并且对系统映射的绝大多数匿名页都进行了命名。因此不论是文件页还是匿名页,在分配信息中都能看到页的命名信息,这对于内存分析非常有帮助。

以上就是HiViewDFX提供的可靠性和性能优化调试调优能力的相关介绍了,欢迎广大开发者使用HiViewDFX框架来开发一个高可靠高性能的应用!


END


想了解更多HarmonyOS技术?

后台留言给我们

立刻安排!


欢迎点击|阅读原文

搜索关键字"dfx"查看更多信息


原文标题:应用可靠性与性能不给力?HarmonyOS HiViewDFX了解一下

文章出处:【微信公众号:HarmonyOS开发者】欢迎添加关注!文章转载请注明出处。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • HarmonyOS
    +关注

    关注

    79

    文章

    1980

    浏览量

    30369

原文标题:应用可靠性与性能不给力?HarmonyOS HiViewDFX了解一下

文章出处:【微信号:HarmonyOS_Dev,微信公众号:HarmonyOS开发者】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    如何测试光耦的性能可靠性

    光耦作为电气隔离的关键组件,其性能可靠性直接影响到整个系统的稳定性和安全。因此,对光耦进行严格的性能测试和可靠性评估是必不可少的。 光耦
    的头像 发表于 01-14 16:13 103次阅读

    驱动钛丝(SMA)的可靠性设计(4) 力量设计

    发生运动。相比于传统的电机、电磁铁动力,钛丝是种新型的动力元件。钛丝驱动技术目前已经在航空航天、洲际导弹、无人机、手机、汽车、机器人等科技领域投入使用。本文通过分享、普及钛丝驱动技术的可靠性
    发表于 11-27 17:49

    半导体封装的可靠性测试及标准

    产品可靠性是指产品在规定的使用条件定时间内,能够正常运行而不发生故障的能力。它是衡量产品质量的重要指标,对提高客户满意度和复购率具有重要影响。金鉴实验室作为家提供检测、鉴定、认
    的头像 发表于 11-21 14:36 263次阅读
    半导体封装的<b class='flag-5'>可靠性</b>测试及标准

    PCB高可靠性化要求与发展——PCB高可靠性的影响因素(上)

    在电子工业的快速发展中,印刷电路板(PCB)的可靠性始终是设计和制造的核心考量。随着集成电路(IC)的集成度不断提升,PCB不仅需要实现更高的组装密度,还要应对高频信号传输的挑战。这些趋势对PCB
    的头像 发表于 10-11 11:20 402次阅读
    PCB高<b class='flag-5'>可靠性</b>化要求与发展——PCB高<b class='flag-5'>可靠性</b>的影响因素(上)

    深入了解IXYS固态继电器:可靠性与应用领域的完美结合

    的控制电路中。它们不仅提高了设备的安全,还减少了因机械磨损导致的故障率。 总的来说,固态继电器作为种高性能的电子开关,在各个领域中都发挥着至关重要的作用。IXYS 提供的固态继电器以其卓越的
    发表于 08-27 15:26

    PCBA测试详解:功能、性能可靠性文掌握核心要点!

    PCBA(Printed Circuit Board Assembly)测试是电子产品制造过程中至关重要的环。它旨在确保电路板及其上安装的电子元器件按照设计要求正确工作,从而达到预期的性能可靠性
    的头像 发表于 08-27 10:26 3764次阅读
    PCBA测试详解:功能、<b class='flag-5'>性能</b>、<b class='flag-5'>可靠性</b>,<b class='flag-5'>一</b>文掌握核心要点!

    汽车功能安全与可靠性的关系

    当前,随着汽车领域的飞速发展,汽车也被重新定义。在汽车电子电气系统设计时,离不开对功能安全和可靠性设计的考虑。正确理解两者之间的关系,有助于更好地分析问题和解决问题。什么是汽车可靠性汽车可靠性是指
    的头像 发表于 07-13 08:28 3251次阅读
    汽车功能安全与<b class='flag-5'>可靠性</b>的关系

    FHT4644国产替代必然崛起你还不来了解一下芯片这些事吗

    FHT4644国产替代必然崛起你还不来了解一下芯片这些事吗 国产芯片崛起,让国内发展环境变得更加稳定,国产芯片FHT4644通过性能实验测试,更高效。实验室常温条件
    发表于 06-24 17:38

    显示器可靠性高低温湿热试验方法_环境可靠性试验设备

    湿热试验的方法和步骤。   高低温湿热试验旨在模拟显示器在不同温度和湿度条件的工作环境,评估其性能可靠性。通过这种试验,可以发现显示器在极端环境的潜在问题,为
    的头像 发表于 06-21 17:39 607次阅读
    显示器<b class='flag-5'>可靠性</b>高低温湿热试验方法_环境<b class='flag-5'>可靠性</b>试验设备

    请问FATFS文件系统可靠性如何?

    ST官方固件库中使用了FATFS文件系统,想问下,这个文件系统可靠么? 我想了解一下,有哪位朋友真正产品上使用FATFS文件系统,可靠性有什么问题没有。
    发表于 05-16 06:35

    提升开关电源可靠性:全面了解测试项目与标准

    开关电源可靠性测试是检测开关电源质量、稳定性和质量的重要手段。可靠性测试也是开关电源测试的关键环节,以此评估开关电源的性能和使用寿命。
    的头像 发表于 03-21 15:50 1012次阅读

    可靠性测试中HALT实验与HASS实验的区别

    电子产品高加速寿命测试HALT、高加速应力筛选测试HASS,都是可靠性测试的方法,用于评估电子产品在恶劣环境性能表现和可靠性。那他们之前的区别是什么呢,跟随本文来
    的头像 发表于 01-30 10:25 1316次阅读
    <b class='flag-5'>可靠性</b>测试中HALT实验与HASS实验的区别

    线路板变形对电路性能可靠性有影响吗?

    线路板变形对电路性能可靠性有影响吗? 线路板是连接和组织电子元件的重要组成部分。线路板的设计和制造对电路性能可靠性有着重要的影响。线路板的变形可能会导致电路的信号传输受损、电子元件
    的头像 发表于 01-29 13:58 716次阅读

    美国站群服务器优化:提升性能可靠性的关键功能

    随着互联网的迅猛发展,网站的性能可靠性成为了企业成功的关键因素之。美国作为全球互联网的中心,其站群服务器在全球范围内都有着广泛的应用。本文将探讨美国站群服务器优化的关键功能,以提升其性能
    的头像 发表于 01-25 11:56 366次阅读

    如何确保IGBT的产品可靠性

    标准。安森美(onsemi)作为家半导体供应商,为高要求的应用提供能在恶劣环境运行的产品,且这些产品达到了高品质和高可靠性。之前我们分享了如何对IGBT进行可靠性测试,今天我们来介
    的头像 发表于 01-25 10:21 1695次阅读
    如何确保IGBT的产品<b class='flag-5'>可靠性</b>