msMemScope快速入门
概述
简介
msMemScope工具提供内存事件采集功能,基于采集事件开展内存泄漏检测、内存对比、内存块监测、内存拆解和低效内存识别等分析功能。本文档通过一个简单的PyTorch脚本介绍msMemScope工具的使用方法以及功能。
环境准备
请根据《msMemScope安装指南》完成安装。
操作步骤
-
设置环境变量。
-
使用CANN运行的用户,请执行以下命令配置环境变量。
source <cann-path>/Ascend/cann/set_env.sh注:其中
cann-path为CANN的安装目录。 -
使用msMemScope工具采集内存数据时,执行以下命令配置环境变量。
source <path>/msmemscope/set_env.sh注:其中
path为msMemScope软件包安装位置。 -
使用msMemScope的Python接口方式需要执行以下命令设置环境变量。推荐将以下命令加入专门的环境变量设置脚本。
msMemScope_DIR="path" # "path"需替换为实际的msMemScope路径 export LD_LIBRARY_PATH=${msMemScope_DIR}/lib64:${LD_LIBRARY_PATH} export LD_PRELOAD=${msMemScope_DIR}/lib64/libleaks_ascend_hal_hook.so:${msMemScope_DIR}/lib64/libascend_mstx_hook.so:${msMemScope_DIR}/lib64/libascend_kernel_hook.so:${msMemScope_DIR}/lib64/libatb_abi_0_hook.so:${msMemScope_DIR}/lib64/libatb_abi_1_hook.so
-
-
进入仓库目录后,执行以下命令进入仓库example目录。
cd ./exampleexample目录下按照使用方式提供了不同代码示例。
- Python接口使用方式:example_api
- 命令行使用方式:example_cmd
-
选择以下其中一种方式使用msMemScope。推荐使用Python接口方式。
-
Python接口使用方式。
提供config、start、stop、step四种API接口。
接口 功能说明 config 设置参数,未指定的参数为默认值。 start 开始采集。 stop 结束采集。 step mstx的“step start”固化信息接口。 通过以下命令执行脚本。
python example_api.py -
命令行使用方式。通过以下命令,使用msMemScope执行脚本。
msmemscope --events=alloc,free,access,launch --level=kernel,op --call-stack=c,python --analysis=leaks,inefficient,decompose --output=./output --data-format=csv python ./example_cmd.py
完整工具参数参考《内存采集》。
-
-
输出结果文件说明。