• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# HiDumper概述
2
3
4## 功能简介
5
6HiDumper是OpenHarmony为开发、测试人员、IDE工具提供的系统信息获取工具,帮助开发者分析、定位问题。本章节内容适用于标准系统。
7
8## 源码目录说明
9
10
11```
12/base/hiviewdfx/hidumper
13├── frameworks           # 框架代码
14│   ├── native           # 导出功能核心代码
15│   │  │── include       # 头文件目录
16│   │  │── src           # 源文件目录
17│   │      │── common    # 通用功能代码
18│   │      │── executor  # 导出过程执行器代码
19│   │      │── factory   # 跟进导出项生成导出执行器
20│   │      │── manager   # 导出管理核心代码
21│   │      │── util      # 工具类源代码
22│── sa_profile           # Hidumper sa属性文件
23│── services             # Hidumper服务源码
24│   │── native           # 服务C++源码
25│   │── zidl             # 通讯功能源码目录
26│   │   │── include      # 通讯功能头文件
27│   │   │── src          # 通讯功能源代码
28├── test                 # 测试用例目录
29│   ├── unittest         # 单元测试代码
30│   ├── moduletest       # 模块级别测试代码
31```
32
33
34# HiDumper使用指导
35
36
37## 命令参数说明
38
39  **表1** HiDumper命令参数说明
40
41| 选项 | **描述** |
42| -------- | -------- |
43| -h | 查看帮助信息。 |
44| -t [timeout] | 超时时间,单位:秒。默认值是30s。如果设置为0表示无超时限定。 |
45| -lc | 查看系统信息簇列表。 |
46| -ls | 查看系统元能力列表。 |
47| -c | 导出系统簇信息。 |
48| -c [base system] | 以base或system标签区分的系统簇信息导出。 |
49| -s | 导出全部系统元能力信息 |
50| -s [SA0 SA1] | 导出SA0、SA1等元能力id对应的元能力信息。 |
51| -s [SA] -a ['-h'] | 以-h为参数导出SA指定的系统元能力信息。 |
52| -e | 导出Faultlog模块生成的崩溃日志。 |
53| --net | 导出网络信息。 |
54| --storage | 导出存储信息。 |
55| -p | 导出进程列表及全部进程信息。 |
56| -p [pid] | 导出指定进程号的进程全部信息。 |
57| --cpuusage [pid] | 导出CPU使用信息。如果指定pid则导出该进程的CPU使用信息。 |
58| --cpufreq | 导出实际的CPU频率 |
59| --mem [pid] | 导出内存使用信息。如果指定pid则导出该进程的内存使用信息。 |
60| --zip | 将导出信息压缩到固定文件夹下。 |
61
62
63## 使用实例
64
65HiDumper可以为开发者导出系统当前基本信息,通过这些基本信息可以定位分析问题。给子服务和元能力传递复杂参数时,参数需要加双引号。
66
67具体步骤如下:
68
691. 进入设备命令行,输入 hidumper -h 获取基本信息介绍,功能语法介绍。
70
71   ```
72   hidumper -h
73   ```
74
752. 输入 hidumper -lc 获取系统信息分类列表。
76
77   ```
78   hidumper -lc
79   ```
80
813. 输入 hidumper -c 获取系统base、system等所有分类信息。
82
83   ```
84   hidumper -c
85   ```
86
874. 输入 hidumper -c [base | system] 按 base 或 system 分类获取系统簇信息。
88
89   ```
90   hidumper -c base
91   hidumper -c system
92   ```
93
945. 输入 hidumper -ls 命令获取系统中元能力列表。
95
96   ```
97   hidumper -ls
98   ```
99
1006. 输入 hidumper -s 命令获取系统全部元能力信息。
101
102   ```
103   hidumper -s
104   ```
105
1067. 运行 hidumper -s 3301 -a "-h" 命令获取id为3301的元能力的帮助。
107
108   ```
109   hidumper -s 3301 -a "-h"
110   ```
111
1128. 运行 hidumper -s 3008命令获取id为3008的元能力的全部信息。
113
114   ```
115   hidumper -s 3008
116   ```
117
1189. 运行 hidumper -e 命令获取Faultlog模块生成的崩溃历史信息。
119
120   ```
121   hidumper -e
122   ```
123
12410. 运行 hidumper --net 命令获取网络信息。
125
126    ```
127    hidumper --net
128    ```
129
13011. 运行 hidumper --storage 命令获取存储相关信息。
131
132    ```
133    hidumper --storage
134    ```
135
13612. 运行 hidumper -p 命令获取进程信息,包括进程、线程的列表和信息。
137
138    ```
139    hidumper -p
140    ```
141
14213. 运行 hidumper -p 1024 命令获取pid为1024的进程信息。
143
144    ```
145    hidumper -p 1024
146    ```
147
14814. 运行 hidumper  --cpuusage [pid] 命令获取CPU的使用信息。如果指定了进程的pid,则只获取该进程的CPU使用信息。
149
150    ```
151    hidumper --cpuusage
152    hidumper --cpuusage 1024
153    ```
154
15515. 运行 hidumper --cpufreq 命令获取每一个CPU核实际运行的频率。
156
157    ```
158    hidumper --cpufreq
159    ```
160
16116. 运行 hidumper --mem [pid] 命令获取全部的内存使用信息。如果指定进程的pid,只获取该进程的内存使用情况。
162
163    ```
164    hidumper --mem [pid]
165    ```
166    当携带pid参数时输出结果中第一列标题的详细说明如下:
167    | 名称             | 描述 |
168    |----------------|----|
169    | GL             | GPU内存   |
170    | Graph          | 图形内存  |
171    | ark ts heap    | ArkTS堆的内存占用  |
172    | guard          | 保护段所占内存   |
173    | native heap    | 堆内存   |
174    | AnonPage other | 其它没有被映射到文件的页所占内存  |
175    | stack          | 栈内存   |
176    | .hap           | 应用程序所占内存   |
177    | .db            | 进程加载的.db数据文件所占内存   |
178    | .so            | 进程加载的.so动态库所占内存   |
179    | .ttf           | 进程加载的.ttf字体文件所占内存   |
180    | dev            | 进程加载的以/dev开头的文件所占内存   |
181    | FilePage other | 其它有被映射到文件的页所占内存   |
182
18317. 运行 hidumper --zip 命令压缩信息数据到/data/dumper目录下。
184
185    ```
186    hidumper --zip
187    ```
188
18918. 运行 hidumper -t timeout 命令设置超时时间,单位:秒。默认值是30s。如果设置为0表示无超时限制。
190
191    ```
192    hidumper -t [timeout]
193    ```
194