麒麟系统开发笔记(十一):在国产麒麟系统上使用gdb定位崩溃异常方法流程进阶定位代码行数及专项测试Demo

简介: 上一篇,通过研究,可以定位到函数,本篇进一步优化,没有行数,程序较为复杂的时候,就无法定位,所以进一步定位。  本篇做了qBreakpad的研究,但是没有成功,过程也还是填出来,后来突然注意到gdb出现行数的方法,并通过了几轮测试以及实战,确实可以定位到行数,所以为了大家方便,把国企麒麟上的Qt崩溃方法分享出来。  本篇文章比较长,就不分篇了,同时还做了专项测试。

前言

  上一篇,通过研究,可以定位到函数,本篇进一步优化,没有行数,程序较为复杂的时候,就无法定位,所以进一步定位。

  本篇做了qBreakpad的研究,但是没有成功,过程也还是填出来,后来突然注意到gdb出现行数的方法,并通过了几轮测试以及实战,确实可以定位到行数,所以为了大家方便,把国企麒麟上的Qt崩溃方法分享出来。

  本篇文章比较长,就不分篇了,同时还做了专项测试。


注意

  阅读者如果一开始有点懵,可能先要看先大致扫一下:《麒麟系统开发笔记(十):在国产麒麟系统上使用gdb定位崩溃异常方法流程以及测试Demo》,本篇也是解决上一篇探讨的遗留问题(只定位了函数,未定位代码行号)。


使用gdb定位Qt的release(国产麒麟系统)

步骤一:修改上一篇demo的pro配置

  (这里是上一篇的demo,只关注红框的即可)

  

网络异常,图片无法展示
|

步骤二:重新编译调试还是没有行号

  

网络异常,图片无法展示
|

  

网络异常,图片无法展示
|

  

网络异常,图片无法展示
|

  与没有-g的时候没有啥区别。

步骤三:多加几层调用追加堆栈测试

  修改下代码:

  

网络异常,图片无法展示
|

  

网络异常,图片无法展示
|

  测试:

  

网络异常,图片无法展示
|

  还是没有堆栈信息:

  

网络异常,图片无法展示
|

步骤四:怀疑是release版本,改为debug测试

  改为debug版本,也没有:

  

网络异常,图片无法展示
|

  不清楚原因,这里博主就没有深究了

步骤五:路回峰转,重启gdb,成功定位

  研究qBreakpad去了,但是qBreakpad也入深坑了,在爬坑的时候,突然注意到gdb的bt指令,所以研究了个把小时qBreakpad又折回来继续了。

  

网络异常,图片无法展示
|

  至此,出现了行号:

  

网络异常,图片无法展示
|


配置调试发布专项测试

  为了确认最简单的方式,所以进行测试:

DEFINES += QT_NO_DEBUG_OUTPUT
DEFINES += QT_NO_WARN_OUTPUT
QMAKE_CXXFLAGS += -g 
#QMAKE_CXXFLAGS += -g3

测试:debug版本,无-g,不屏蔽qt打印输出

  

网络异常,图片无法展示
|

测试:debug版本,有-g的,不屏蔽qt打印输出

  

网络异常,图片无法展示
|

  有行号,行号跟函数在同一行。

测试:debug版本,有-g的,屏蔽qt打印输出

  

网络异常,图片无法展示
|

  有行号,行号跟函数在同一行。

测试:release版本,有-g/-g3,有qt屏蔽打印输出

#DEFINES += QT_NO_DEBUG_OUTPUT
#DEFINES += QT_NO_WARN_OUTPUT
QMAKE_CXXFLAGS += -g 
#QMAKE_CXXFLAGS += -g3

  

网络异常,图片无法展示
|

  

网络异常,图片无法展示
|

  

网络异常,图片无法展示
|

  还试了下-g3:

  

网络异常,图片无法展示
|

  定位了函数,不定位行号。

测试:release版本,有-g/-g3,未屏蔽qt打印输出

  

网络异常,图片无法展示
|

  所以,最终发现是不能屏蔽qt打印输出的,不然是没有的,跟release或者debug没有关系(没有去论证debug下屏蔽qt打印输出了)

测试:release版本,无-g,未屏蔽qt打印输出

  

网络异常,图片无法展示
|

  所以,无-g也不行

模拟实战

  先加了一句代码:

  

网络异常,图片无法展示
|

  取消屏蔽qt打印,加上-g:

  

网络异常,图片无法展示
|

  使用release编译后,运行崩溃:

  

网络异常,图片无法展示
|

  定位coredump文件:

  

网络异常,图片无法展示
|

  然后使用gdb的方法:

  

网络异常,图片无法展示
|

  这里得行是qlist.h的行号,不是我们代码的行号,所以下标错误估计就这样了。可以判断出,越界也是最后某个地方调用指针导致错误,所以越界当时是不会有问题,当越界在用越界调用的就把出错的指针调用出行数打出来。

  下面试试指针错误:

  

网络异常,图片无法展示
|


专项测试结论

  

网络异常,图片无法展示
|


入坑

入坑一:gdb不出现行数

问题

  Gdb调试不出现行数

原因

  • 原因1:release与debug问题
  • 原因2:-g问题
  • 原因3:是否屏蔽qt打印问题
      1+2+3,导致情况多种,花了不少时间定位

解决

  进行了专项测试论证,查看“专项测试论证”。


qBreakpad(此方法未通,贴出来参考,有兴趣的读者可以继续往下走)

  qBreakpad下载地址:https://github.com/buzzySmile/qBreakpad

git clone --recursive https://github.com/buzzySmile/qBreakpad.git

  好像下下来有点问题,最后还是手动下载zip包了:

  

网络异常,图片无法展示
|

  qBreakpad依赖breakpad和lss

  

网络异常,图片无法展示
|

  下不下来,另外找把

  breakpad下载地址:https://github.com/google/breakpad

  (最新版报错),下载v2021.08.09版本

  

网络异常,图片无法展示
|

  lss:https://github.com/ithaibo/linux-syscall-support

  下载来:

网络异常,图片无法展示
|


编译qBreakpad库

步骤一:下载解压

  

网络异常,图片无法展示
|

步骤二:复制改名依赖库

  复制过去并改名:

  

网络异常,图片无法展示
|

  改完后(先删除已经存在的):

  

网络异常,图片无法展示
|

步骤三:使用qtcreator打开qBreakpad编译

  

网络异常,图片无法展示
|

步骤四:解决错误“undefined reference to `google_breakpad::PEFile::TryGetDebugInfo(xxxx”,继续编译

  怀疑是版本问题,降低版本试试:

  

网络异常,图片无法展示
|

  如下,下载解压后替换:

  

网络异常,图片无法展示
|

步骤五:解决错误“*** No rule to make target ‘xxx/minidump_file_writer.cc’, needed by ‘_build/obj/minidump_file_writer.o’. Stop.”

  “*** No rule to make target ‘…/…/qBreakpad-master/third_party/breakpad/src/client/minidump_file_writer.cc’, needed by ‘_build/obj/minidump_file_writer.o’. Stop.”


  那岂不是要降低qBreakpad的版本?试一试

  至此,突然发现gdb的bt,所以这边停止了。

相关实践学习
阿里云图数据库GDB入门与应用
图数据库(Graph Database,简称GDB)是一种支持Property Graph图模型、用于处理高度连接数据查询与存储的实时、可靠的在线数据库服务。它支持Apache TinkerPop Gremlin查询语言,可以帮您快速构建基于高度连接的数据集的应用程序。GDB非常适合社交网络、欺诈检测、推荐引擎、实时图谱、网络/IT运营这类高度互连数据集的场景。 GDB由阿里云自主研发,具备如下优势: 标准图查询语言:支持属性图,高度兼容Gremlin图查询语言。 高度优化的自研引擎:高度优化的自研图计算层和存储层,云盘多副本保障数据超高可靠,支持ACID事务。 服务高可用:支持高可用实例,节点故障迅速转移,保障业务连续性。 易运维:提供备份恢复、自动升级、监控告警、故障切换等丰富的运维功能,大幅降低运维成本。 产品主页:https://www.aliyun.com/product/gdb
相关文章
|
18天前
|
Java
IDEA快捷测试方法可用性
IDEA快捷测试方法可用性
17 0
|
21天前
|
数据可视化 测试技术
深入理解软件测试中的风险评估方法
【4月更文挑战第19天】 在软件开发的生命周期中,风险评估是确保产品质量和项目成功的关键步骤。本文将探讨几种常用的软件测试风险评估方法,包括定性分析和定量分析,并讨论它们在不同类型的测试环境中的应用。通过案例研究和最佳实践,我们将展示如何有效识别、评估和管理测试过程中可能遇到的风险,以及如何制定相应的缓解策略,以优化资源分配和提高测试效率。
|
2月前
|
人工智能 测试技术 持续交付
现代软件测试方法探析及应用前景展望
随着信息技术的迅猛发展,软件在我们日常生活和工作中扮演着愈发重要的角色。而为了保证软件质量和稳定性,软件测试显得尤为重要。本文将探讨现代软件测试方法的演变和应用前景,并分析其在不断变化的技术环境下的发展趋势。
|
2月前
|
设计模式 安全 测试技术
【软件设计师备考 专题 】系统实施:程序设计和系统测试
【软件设计师备考 专题 】系统实施:程序设计和系统测试
66 0
|
2月前
|
Java Spring
使用JDBCTemplate实现与Spring结合,方法公用 ——测试(EmpDaoImplTest)
使用JDBCTemplate实现与Spring结合,方法公用 ——测试(EmpDaoImplTest)
9 0
|
15天前
|
测试技术 API Python
Appium控件交互策略:优化自动化测试效率的关键方法
该文介绍了如何使用Selenium与APP进行交互,包括点击、输入和状态判断等操作。例如,通过element.click()点击控件,element.send_keys()输入文本,以及element.is_displayed()检查元素是否可见。还展示了如何获取元素属性,如resource-id、text和class,并提供了Python代码示例来定位并操作APP元素,如滑动条的显示、可点击性检测及点击滑动条中心位置。在编写测试脚本时,应注意元素定位和状态验证以确保测试稳定性。
20 1
|
20天前
|
消息中间件 网络协议 物联网
如何入门做物联网系统压测?
【4月更文挑战第18天】物联网系统在架构、网络模式、通信协议等方面与传统的互联网系统有所区别。因此,传统的性能测试方法不能直接套用到物联网系统中。
98 13
如何入门做物联网系统压测?
|
1天前
|
传感器 编解码
LabVIEW编程LabVIEW开发 控制RITEC RAM-5000 SNAP非线性高能超声测试系统例程与相关资料
LabVIEW编程LabVIEW开发 控制RITEC RAM-5000 SNAP非线性高能超声测试系统例程与相关资料
|
3天前
|
存储 测试技术 数据库
深入理解自动化测试中的数据驱动方法
【5月更文挑战第7天】 在快速发展的软件行业中,为了提升测试效率和测试覆盖率,自动化测试已经成为一个不可或缺的部分。数据驱动测试(DDT)是一种独特的自动化测试方法,它允许分离测试逻辑和测试数据,从而使得测试案例可以更加灵活和有效地进行管理。本文将探讨数据驱动测试的核心概念、实施步骤及其在实际应用中的优势与挑战。通过对多个案例的分析,我们旨在提供一个全面的指南,帮助软件测试人员理解和运用数据驱动方法以优化他们的自动化测试策略。
|
10天前
|
存储 大数据 测试技术
矢量数据库的性能测试与评估方法
【4月更文挑战第30天】本文探讨了矢量数据库的性能测试与评估方法,强调其在大数据和AI时代的重要性。文中介绍了负载测试、压力测试、容量测试、功能测试和稳定性测试五大评估方法,以及实施步骤,包括确定测试目标、设计用例、准备环境、执行测试和分析结果。这些方法有助于确保数据库的稳定性和高效性,推动技术发展。

热门文章

最新文章