iOS崩溃日志ips文件解析

iOS崩溃日志ips文件解析

一 简介

  测试组的同事在进行稳定性测试时,通常会遇到一些崩溃,然后他们会将这些崩溃日志(一般是ips格式的文件)反馈给开发进行分析,但是这些ips文件中的内容通常是如下图这样的,都是一些十六进制的堆栈地址,如果仅仅根据这些堆栈地址,我们基本无法做任何事情,连最基本的崩溃定位都做不到。那么,在iOS开发中,还有一些其他的方法可以帮助我们将这些堆栈信息转化为可视化的日志文件,在转化后的可视化日志文件中,我们可以清晰定位到我们的应用崩溃的位置,如下图2所示。

  这个转化的过程有一个专业术语,叫符号化,就是讲这些堆栈地址转化为我们可识别的一些类名、方法名等符号信息。

二 解析步骤

  所以,如何实现这样的转化是一个很重要的问题。网上查了很多资料,现在网上一般说是有两种方法:

  • 命令行解析ips
  • 使用Xcode解析ips/crash

2.1 准备工作,获取.xcarchive文件

  我主要采用的是第一种方法利用命令行解析ips,在这种方法中,有一个前提准备工作要做,就是要获得我们打包时的.xcarchive文件,具体获取方法是打开xcode,点击 【window】 --> 【Organizer】,进入到我们打包Archives的管理界面,这个界面有我们之前打的包的所有记录,选择测试App对应的App以及打包的版本,单击选中的Archive选择 show in Finder,然后将对应的.xcarchive文件拷贝出来,放在桌面或其他自己方便查看的地方。如果不是你负责打包,那么你需要找到打包负责人拿到对应的.xcarchive文件。

2.2 解析具体步骤

  1. 新建一个文件夹,名字叫Acrash。
  2. 拷贝.ips文件放到Acrash中,并将.ips文件后缀名该为.crash。 
  3. 前往文件夹路径:【/Applications/Xcode.app/Contents/SharedFrameworks/DVTFoundation.framework/Versions/A/Resources/symbolicatecrash】,找到symbolicatecrash。拷贝symbolicatecrash工具拷贝到Acrash中。具体步骤是打开Finder,【前往】-->【 前往文件夹】,在弹出的对话框中输入上述地址/Applications/Xcode.app/Contents/SharedFrameworks/DVTFoundation.framework/Versions/A/Resources/symbolicatecrash,点击【前往】即可定位到对应的symbolicatecrash工具,然后选择拷贝即可。
  4. 从xcarchive文件里,右键点击【显示包内容】,从Products/Applications里面拷贝.app文件,放到Acrash中。
  5. 从xcarchive文件里,右键点击【显示包内容】,拷贝dSYMs文件下的.dSYM文件,放到Acrash中。

    至此,Acrash文件中总共有4个文件:.crash文件、symbolicatecrash工具、app文件、.dSYM文件。

6. 打开终端,cd到Acrash文件夹中

7. 输入命令  ./symbolicatecrash crash文件的绝对路径 dSYM的绝对路径 > log.crash ,回车。

    【注意1】:log.crash是符号化后的文件名。可以自定义文件名(后缀一定是.crash哈)。

    【注意2】:7步骤之后,终端有可能会报错Error: Error: "DEVELOPER_DIR" is not defined at ./symbolicatecrash line 69.. 这时候在终端中再输入

export DEVELOPER_DIR="/Applications/Xcode.app/Contents/Developer

        然后再次运行 7 的命令。应该就能看到Acrash文件夹下,可以发现多了一个文件:log.crash。

  OK,整个过程基本就是这样了,得到最后的log.crash之后,我们就比较方便定位问题所在了。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏bboysoul

使用mkdocs管理你的博客或者文档

其实我是想找一个文档管理的东西,无意间知道了mkdocs,感觉还不错,是使用python做的一个静态网站生成器

25120
来自专栏LinXunFeng的专栏

Cocoapods 创建第三方框架

13430
来自专栏知晓程序

如何在小程序中接入微信登录?

今天,知晓程序(微信号 zxcx0101)为大家分享服务器端基于 Java、SpringMVC 实现的微信小程序登录系统。

12430
来自专栏SpringBoot 核心技术

第十五章:使用SpringBoot validator让数据更真实

16830
来自专栏阮一峰的网络日志

HTTP/2 服务器推送(Server Push)教程

HTTP/2 协议的主要目的是提高网页性能。 头信息(header)原来是直接传输文本,现在是压缩后传输。原来是同一个 TCP 连接里面,上一个回应(respo...

35750
来自专栏教程

Centos7搭建WordPress个人站点(整理)

本教程使用服务器腾讯云云服务器 CVM(以下简称 CVM),以 Linux 系统 CentOS 7.0以上为例,来完成 WordPress 搭建工作。

4.5K150
来自专栏前端vue

VuePress搭建永久文档/博客网站VuePress 使用

保存并提交代码至github,提交代码后等待1分钟 浏览器访问 http://自己的github用户名.github.io 看到hello github 到这...

65030
来自专栏月牙寂

docker源码分析(2)---docker server

第一时间获取文章,可以关注本人公众号 月牙寂道长 yueyajidaozhang

34960
来自专栏Java学习123

Windows平台kafka环境的搭建

19030
来自专栏听雨堂

ASP.NET调用word开发环境下正常,iis下报错

检索 COM 类工厂中 CLSID 为 {00024500-0000-0000-C000-000000000046} 的组件时失败,原因是出现以下错误: 800...

21060

扫码关注云+社区

领取腾讯云代金券