iOS 崩溃日志解析

一、从 iPhone 等设备中获取崩溃日志并解析 - symbolicatecrash

symbolicatecrash 程序路径(Xcode 9.4.1):
/Applications/Xcode.app/Contents/SharedFrameworks/DVTFoundation.framework/Versions/A/Resources/symbolicatecrash

1、Copy symbolicatecrash 程序到 ~/Desktop/CrashAnalyze 目录
2、创建一个工程 CrashDemo,包含会导致崩溃的代码

#import "CustomViewController.h"

@implementation CustomViewController

- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event
{
    [self generateCrash];
}

- (void)generateCrash
{
    NSArray *array = [NSArray array];
    id obj = [array objectAtIndex:0]; // 这一行崩溃
    NSLog(@"obj -- %@", obj);
}

@end

3、打包并导出 .ipa,安装到 iPhone, 启动 APP 并触发崩溃


exportipa.png

4、打开 Xcode -> Window -> Devices and Simulators -> 选中设备 -> View Device Logs,可以看到设备的所有日志,包括崩溃日志。


crash_report.png

5、将日志导出(选中崩溃日志 -> 鼠标右键 -> Export Log), 保存到和 symbolicatecrash 同一目录 ~/Desktop/CrashAnalyze,后缀名为默认 .crash, 可任意命名,这里命名为 first.crash。

6、copy .dSYM 文件和 .app 文件
打开 Xcode -> Window -> Organizer -> CrashDemo -> Archives -> 刚打的包 -> 右键 -> Show in Finder, 在 .xcarchive 中找到。
这里碰到一个问题:
以前打包的 .xcarchive(具体 Xcode 版本不详),里面只有1个 .dSYM 文件,即名称为“YourAPPName.app.dSYM”,但是 Xcode9.4.1 打包的 .xcarchive,里面有3个 .dYSM文件,


3_dYSM_files.png

另外关于 uuid,.dYSM 文件,.crash 文件和 .app 文件都有 uuid,三者一致时说明是它们是对应的,可以用于符号化解析; 只是这里的 *.app.dSYM 的2个 uuid 与 .crash 文件的 uuid 不一致,另外2个长串名称的其中1个的 uuid 与 .crash 的 uuid 一致,但是用于符号化解析时提示"No symbolic information found", 不能正常解析。

获取 .dYSM 文件 uuid 的方法,输入以下命令

dwarfdump --uuid .dSYM文件名

得到类似以下结果

UUID: 02000565-D5A9-3627-81E5-659B2AC06791 (arm64) 02000565-D5A9-3627-81E5-659B2AC06791.dSYM/Contents/Resources/DWARF/CrashDemo

这里可以看到,与 .app.dSYM 不同的是,这个长串名称的 .dSYM 文件名刚好就是 uuid。

.crash文件的 uuid 可以通过下面的方式找到:
打开 .crash 文件,找到“Binary Images:”行,则这一行的下一行就包含 uuid


crash_uuid_position.png

总结一下目前.xcarchive里的.dsym文件和.app文件的uuid,.crash文件的uuid,导出的.ipa内的.app文件的uuid之间是否一致的情况:

  1. .xcarchive 里的 CrashDeme.app.dsym 的 uuid 有2个,与 .xcarchive 里的 .app 的2个 uuid 一致;
  2. .xcarchive 里的2个长串名称 .dysm 的 uuid,与导出的 .ipa 内的 .app 文件的2个 uuid 一致,与 .crash 的 uuid 也一致,即3者都一致;
  3. 以上1)和2)的 uuid 不一致。

............

现在已找到生成3个 .dSYM 文件的原因:开了 Bitcode. 而如果 Bitcode 是关闭的,就只会产生1个.dSYM, 且它的 uuid 与 .crash 一致。
感谢这篇文章的介绍。
重新导出 .crash 可以看到,崩溃的位置和原因已经被解析出来了

crash_reason.png

按正常方法继续解析崩溃日志:
将 symbolicatecrash,first.crash, CrashDemo.app.dSYM 放到同一个文件夹,执行以下命令

./symbolicatecrash first.crash CrashDemo.app.dSYM > new.crash

这里仍然输出了“No symbolic information found”,new.crash 的内容与 first.crash 完全一致。

虽然最终得到了想要的结果(崩溃原因和位置),但是仍然遗留以下问题:
1.Bitcode 打开时得到的多个 .dSYM 和多个 uuid 的含义和关系,如何对 .crash 进行符号化;
2.Bitcode 关闭,.crash 直接包含崩溃原因和位置,解析时仍出现“No symbolic information found",原理是什么。

二、第三方工具收集日志和解析 - atos

百度统计为例, 日志导出如下:

百度统计收集的崩溃日志.png

日志程序崩溃时每个线程的堆栈信息,其中有 Crashed 标识的线程为崩溃所在线程。找到有 APP Name 的行,用后面的地址可解析。
运行如下命令(arm 64)

atos -o yourAPP.app.dSYM/Contents/Resources/DWARF/yourAPP -l 0x1006b4000 0x0000000100d382a8 -arch arm64

其中 0x1006b4000,0x0000000100d382a8 两个地址分别对应崩溃日志中的地址。
输出结果即为符号化的信息,如类名,方法名等。

最后编辑于
?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,100评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,308评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,718评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,275评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,376评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,454评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,464评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,248评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,686评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,974评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,150评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,817评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,484评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,140评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,374评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,012评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,041评论 2 351

推荐阅读更多精彩内容