[√]addr2line vscode插件

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: [√]addr2line vscode插件

LeakTracer 的内存泄露日志

# LeakTracer report diff_utc_mono=1685831038.201270
leak, time=1832269.756888, stack=0x61b18 0x66024 0x662b8 0x5f5d0 0x6d36aed8, size=100, data=.p..z...............z.............................

使用addr2line命令行查看到的堆栈信息

image.png

很明显已经定位到了泄露的位置

image.png

不过整个流程稍微有点长,大致步骤为:

  1. adb连接手机,方便我们后续使用adb命令将leaktracer的泄露日志拉取到电脑分析
  2. 安装app,并产生leaktracer的泄露日志
  3. adb pull leak-report.txt
  4. 使用addr2line命令分析leak-report.txt,这里面需要提取出stack,还需要配合对应的so文件
  5. 跳转到对应的源码位置,分析堆栈,找出原因。

所以就顺手写了一个vscode插件,从手机上将这个日志导入到插件,自动分析日志,图形化展示出来,点击跳转到源码,方便快速定位。

image.png

插件已经发布到vscode扩展商店。

插件的配置项

 "a2la.ips": ["192.168.1.33:6666"],// 记录手机的ip,主要是为了连接手机,方便后续调用adb命令
  "a2la.apps": ["com.example.jni"],// 拉取日志的app包名
  "a2la.leak-file": "files/Documents/leak_report.txt",// 内存泄露日志文件
  "a2la.local-files": { // 每一次拉取分析日志,都会将日志保存到本地
    "192.168.1.23:6666-com.example.jni": [
      "C:\\Users\\cc\\leak\\leak_report_1687316414070.txt",
      "C:\\Users\\cc\\leak\\leak_report_1687316889163.txt",
      "C:\\Users\\cc\\leak\\leak_report_1687317321308.txt"
    ],
    "192.168.1.33:6666-com.example.jni": [
      "C:\\Users\\cc\\leak\\leak_report_1687655352416.txt",
      "C:\\Users\\cc\\leak\\leak_report_1687660996658.txt",
      "C:\\Users\\cc\\leak\\leak_report_1687663468221.txt",
      "C:\\Users\\cc\\leak\\leak_report_1687663556916.txt"
    ]
  },
  "a2la.executable-file": "g:\\proj\\jni\\app\\build\\intermediates\\ndkBuild\\debug\\obj\\local\\arm64-v8a\\libjni.so"// 带符号表的对应so库文件

a2la.appa2la.leak-file是为adb pull命令服务的,因为我的日志是保存在getExternalFilesDirs(Environment.DIRECTORY_DOCUMENTS);

adb pull /storage/emulated/0/Android/data/com.example.jni /files/Documents/leak_report.txt

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
3月前
|
自然语言处理 API C++
阿里通义推出SmartVscode插件,自然语言控制VS Code,轻松开发应用,核心技术开源!
SmartVscode插件深度解析:自然语言控制VS Code的革命性工具及其开源框架App-Controller
|
7天前
|
机器学习/深度学习 人工智能 自然语言处理
|
4天前
|
人工智能 小程序 程序员
【视频测评 DEMO 参考】VSCode 神级 AI 插件通义灵码:完全免费+实战教程+微信贪吃蛇小程序
VSCode 神级 AI 插件通义灵码:完全免费+实战教程+微信贪吃蛇小程序
90 7
|
6月前
|
iOS开发 MacOS
【Mac系统】解决Vscode中LeetCode插件不能刷剑指offer题库
文章讨论了解决Mac系统中Vscode里LeetCode插件无法刷剑指Offer题库的问题,并提供了一些相关的使用技巧和资源链接。
341 1
|
3月前
|
开发工具 C++ git
利用VS Code提升开发效率的五大插件推荐
本文推荐了五款能显著提升开发效率的VS Code插件:ESLint用于代码质量和风格检查;Prettier自动格式化代码;GitLens增强Git功能;Live Server提供前端实时预览;Docker支持容器管理。
|
4月前
|
自然语言处理 JavaScript 开发者
通义灵码插件:VSCode 的智能编程助手
通义灵码插件:VSCode 的智能编程助手
1712 3
|
4月前
|
前端开发 JavaScript 编译器
2024最新VSCode实用插件推荐,开发效率遥遥领先!超全面,快收藏~
【10月更文挑战第11天】2024最新VSCode实用插件推荐,开发效率遥遥领先!超全面,快收藏~
1106 0
2024最新VSCode实用插件推荐,开发效率遥遥领先!超全面,快收藏~
|
6月前
|
前端开发 Go
vscode10大常用插件
本文介绍了前端开发中常用的工具及VSCode必备插件。推荐使用VSCode作为入门工具,并介绍了WebStorm和HBuilder等其他选项。VSCode插件包括:Open-In-Browser、live-server、Beautify、Code Runner、Image Preview、Path Intellisense、Turbo Console Log、css-auto-prefix、Bracket Pair Colorizer 和 Auto Rename Tag,这些插件能够显著提升开发效率和代码质量。此外,还提供了录制Gif图的工具GifCam。
197 5
|
5月前
|
人工智能 C++ 开发者
verilog vscode 与AI 插件
【9月更文挑战第11天】在Verilog开发中,使用Visual Studio Code(VS Code)结合AI插件能显著提升效率。VS Code提供强大的编辑功能,如语法高亮、自动补全和代码格式化;便捷的调试功能,支持多种调试器;以及丰富的插件生态。AI插件则可自动生成代码、优化现有代码、检测并修复错误,还能自动生成文档。常用插件包括Verilog AI Assistant和Verilog Language Server,可根据需求选择合适的工具组合,提高开发效率和代码质量。
376 2
|
6月前
|
前端开发 IDE 开发工具
OpenSumi问题之OpenSumi 对于 VS Code 插件生态要如何支持
OpenSumi问题之OpenSumi 对于 VS Code 插件生态要如何支持
154 6

热门文章

最新文章