赞
踩
Faultloggerd部件是OpenHarmony中C/C++运行时崩溃临时日志的生成及管理模块。面向基于 Rust 开发的部件,Faultloggerd 提供了Rust Panic故障日志生成能力。系统开发者可以在预设的路径下找到故障日志,定位相关问题。
目前主要支持对以下C/C++运行时崩溃异常信号的处理:
目录
faultloggerd/ ├── OAT.xml ├── common # 工具库和公共定义 ├── docs # 文档 ├── example # 样例代码 ├── frameworks # 主动抓栈实现 ├── interfaces │ ├── innerkits │ │ ├── backtrace # 本地回栈库 │ │ ├── dump_catcher # 抓取调用栈基础库 │ │ ├── faultloggerd_client # 崩溃临时日志管理服务客户端接口 │ │ └── signal_handler # 异常信号处理器 │ └── rust │ ├── panic_handler # Rust Panic 处理器 │ ├── panic_report # Rust Panic 故障上报库 │ └── rustc_demangle # Rust demangle 库 ├── services # faultloggerd 常驻服务 ├── test │ ├── funchook # hook 工具测试用例 │ ├── fuzztest # 模糊测试用例 │ ├── moduletest # 模块测试用例 │ ├── performancetest # 性能测试用例 │ ├── systemtest # 系统测试用例 │ └── unittest # 单元测试用例 └── tools ├── crasher_c # 崩溃构造器(C) ├── crasher_cpp # 崩溃构造器(C++) ├── dump_catcher # DumpCatcher 命令行工具 ├── panic_maker # Rust Panic 故障构造器 └── process_dump # 崩溃抓栈实现
目前已默认开启,进程因上述异常信号崩溃将会在设备 /data/log/faultlog/temp 目录下生成完整的崩溃日志,可基于该崩溃日志进行问题定位可分析。
崩溃日志介绍和和常见问题指南参看:faultloggerd FAQ
DumpCatcher是提供给第三方模块使用的抓取调用栈基础库,其中包含了打印指定进程(或线程)的栈信息的接口函数。目前支持CPP调用栈和CPP-JS混合栈。
接口类名:DfxDumpCatcher
接口定义:
接口参数说明:
注意:此接口需要调用者是管理员(system,root)用户,或者只抓取自己用户拥有的进程信息。
样例代码:
#ifndef DUMP_CATCHER_DEMO_H #define DUMP_CATCHER_DEMO_H #include <inttypes.h> #define NOINLINE __attribute__((noinline)) #define GEN_TEST_FUNCTION(FuncNumA, FuncNumB) \ __attribute__((noinline)) int TestFunc##FuncNumA() \ { \ return TestFunc##FuncNumB(); \ } // test functions for callstack depth test int TestFunc0(void); int TestFunc1(void); int TestFunc2(void); int TestFunc3(void); int TestFunc4(void); int TestFunc5(void); int TestFunc6(void); int TestFunc7(void); int TestFunc8(void); int TestFunc9(void); int TestFunc10(void); #endif // DUMP_CATCHER_DEMO_H
#include "dump_catcher_demo.h" #include <iostream> #include <string> #include <unistd.h> #include "dfx_dump_catcher.h" using namespace std; NOINLINE int TestFunc10(void) { OHOS::HiviewDFX::DfxDumpCatcher dumplog; string msg = ""; bool ret = dumplog.DumpCatch(getpid(), gettid(), msg); if (ret) { cout << msg << endl; } return 0; } // auto gen function GEN_TEST_FUNCTION(0, 1) GEN_TEST_FUNCTION(1, 2) GEN_TEST_FUNCTION(2, 3) GEN_TEST_FUNCTION(3, 4) GEN_TEST_FUNCTION(4, 5) GEN_TEST_FUNCTION(5, 6) GEN_TEST_FUNCTION(6, 7) GEN_TEST_FUNCTION(7, 8) GEN_TEST_FUNCTION(8, 9) GEN_TEST_FUNCTION(9, 10) int main(int argc, char *argv[]) { TestFunc0(); return 0; }
import("//base/hiviewdfx/faultloggerd/faultloggerd.gni") import("//build/ohos.gni") config("dumpcatcherdemo_config") { visibility = [ ":*" ] include_dirs = [ ".", "//utils/native/base/include", "//base/hiviewdfx/faultloggerd/interfaces/innerkits/dump_catcher/include/", ] } ohos_executable("dumpcatcherdemo") { sources = [ "dump_catcher_demo.cpp" ] configs = [ ":dumpcatcherdemo_config" ] deps = [ "//base/hiviewdfx/faultloggerd/interfaces/innerkits/dump_catcher:libdfx_dumpcatcher", "//utils/native/base:utils", ] external_deps = [ "hilog:libhilog" ] install_enable = true part_name = "faultloggerd" subsystem_name = "hiviewdfx" }
# ./dumpcatcherdemo #00 pc 0000000000000981(00000000004a8981) /data/test/dumpcatcherdemo #01 pc 0000000000000a6d(00000000004a8a6d) /data/test/dumpcatcherdemo #02 pc 0000000000000a63(00000000004a8a63) /data/test/dumpcatcherdemo #03 pc 0000000000000a59(00000000004a8a59) /data/test/dumpcatcherdemo #04 pc 0000000000000a4f(00000000004a8a4f) /data/test/dumpcatcherdemo #05 pc 0000000000000a45(00000000004a8a45) /data/test/dumpcatcherdemo #06 pc 0000000000000a3b(00000000004a8a3b) /data/test/dumpcatcherdemo #07 pc 0000000000000a31(00000000004a8a31) /data/test/dumpcatcherdemo #08 pc 0000000000000a27(00000000004a8a27) /data/test/dumpcatcherdemo #09 pc 0000000000000a1d(00000000004a8a1d) /data/test/dumpcatcherdemo #10 pc 0000000000000a13(00000000004a8a13) /data/test/dumpcatcherdemo #11 pc 0000000000000a77(00000000004a8a77) /data/test/dumpcatcherdemo #12 pc 00000000000c2b08(00000000b6fafb08) /system/lib/ld-musl-arm.so.1(__libc_start_main+116) #13 pc 0000000000000938(00000000004a8938) /data/test/dumpcatcherdemo #14 pc 00000000000008c4(00000000004a88c4) /data/test/dumpcatcherdemo
DumpCatcher 是指提供给用户的一个抓取调用栈命令行工具,由 DumpCatcher innerkits 接口封装实现,该工具通过 -p、-t 参数指定进程和线程,以及 [-c -m -k] 可选参数指定抓栈的类型,命令执行后在命令行窗口打印指定的进程的线程栈信息。
工具名称:dumpcatcher
位置:/system/bin
参数说明:
返回打印说明:如果栈信息解析成功,则将信息显示到标准输出。
注意:使用此接口需要调用者是管理员(system,root)用户。
TODO
// TODO
DFX子系统
hiviewdfx_hiview
hiviewdfx_hilog
hiviewdfx_hiappevent
hiviewdfx_hisysevent
hiviewdfx_faultloggerd
hiviewdfx_hilog_lite
hiviewdfx_hievent_lite
hiviewdfx_hiview_lite
为了帮助大家更深入有效的学习到鸿蒙开发知识点,小编特意给大家准备了一份全套最新版的HarmonyOS NEXT学习资源,获取完整版方式请点击→HarmonyOS教学视频:https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3
鸿蒙生态应用开发白皮书V2.0PDF: 获取完整版白皮书方式请点击→https://docs.qq.com/doc/DZVVkRGRUd3pHSnFG?u=a42c4946d1514235863bb82a7b2ac128
https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3
1.应用开发导读(ArkTS)
2………
https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3
1.系统定义
2.技术架构
3.技术特性
4.系统安全
5…
https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3
1.基本概念
2.构建第一个ArkTS应用
3…
https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3
1.应用基础知识
2.配置文件
3.应用数据管理
4.应用安全管理
5.应用隐私保护
6.三方应用调用管控机制
7.资源分类与访问
8.学习ArkTS语言
https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3
1.Ability开发
2.UI开发
3.公共事件与通知
4.窗口管理
5.媒体
6.安全
7.网络与链接
8.电话服务
9.数据管理
10.后台任务(Background Task)管理
11.设备管理
12.设备使用信息统计
13.DFX
14.国际化开发
15.折叠屏系列
更多了解更多鸿蒙开发的相关知识可以参考:https://docs.qq.com/doc/DZVVBYlhuRkZQZlB3
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。