iOS 崩溃日志分析

个人对iOS崩溃日志分析的使用记录。

一、无dsym文件:参考链接: https://www.cnblogs.com/ciml/p/7422872.html#commentform

主要使用了restore-symbol的一个工具,然后3步走:①修改工具restore-symbol权限 :chmod a+x restore-symbol;② 我们拿到的崩溃日志来自arm64机器,所以先将二进制文件 CrashTest.app/CrashTest 瘦身 (必须正确选择目标CPU架构类型,否则解析出来也是错的,有的包可以跳过这一步):lipo -thin arm64 CrashTest -output CrashTest-arm64。接着用工具恢复符号表:./restore-symbol -o CrashTest-symbol CrashTest-arm64;③使用苹果自带命令行工具atos,将崩溃地址解析成具体函数:atos -arch arm64 -o CrashTest-symbol -l 0x100030000 0x100034340 0x1000342b0。

# 简单解释一下这个命令,atos -arch CPU架构 -o 进制文件 -l 起始地址 ...一系列内存地址 ; -l 后面跟的是模块的起始地址,再后面可以罗列很多地址,该命令会依次解析出具体函数。最后输出结果类似:-[ViewController getChild:] (inCrashTest-symbol) +64-[ViewController crashOnFunc:] (inCrashTest-symbol) +44。后面有的还会提示具体代码错误行数

注意事项:有这样个场景需要注意,CrashTest.app/CrashTest原代码文件必须与测试手机装的版本一模一样,否则符号化后的函数以及具体地址是不正确的,或者在CrashTest原代码改动小的情况下符号化后的函数以及具体地址是大概正确,但不准确的。那么就有一点需要注意,每个需要测试的版本或是上线的版本,都需要保存其CrashTest文件。为什么说需要注意这点呢,因为其实诸如小公司开发,给测试安装的包是不备份的,上线的有.xcarchive文件,里面可以找到线上的app文件;甚至说这边测试测着,开发的小伙伴(比如我)在那边修改优化一些代码或删除一些文件之类的,造成比如一个V0.1.0,都是build1的版本,但无法完全解析出测试给出的崩溃代码的正确函数及位置。


二、有dsym文件的其实网上资料比较多,这里记录下自己的使用过程:

首先是.crash、xx.app、xx.app.dSYM 3个文件的UUID需要一致(xx.app其实没用到,也可以不看)

1.查看 xx.app 文件的 UUID,terminal 中输入命令 : dwarfdump --uuid xx.app/xx (xx代表你的项目名)

2.查看 xx.app.dSYM 文件的 UUID ,在 terminal 中输入命令: dwarfdump --uuid xx.app.dSYM

3.查看 xx.crash 文件的 UUID:grep "AppName arm64"  a.crash(而不是原来友盟说的crash 文件第一行)

就是找到Xcode中的symbolicatecrash工具咯,路径为:/Applications/Xcode.app/Contents/SharedFrameworks/DVTFoundation.framework/Versions/A/Resources/symbolicatecrash。

crash文件的分析

①.配置环境变量DEVELOPER_DIR,(配置好了就不再需要)export DEVELOPER_DIR=/Applications/Xcode.app/Contents/Developer

②使用symbolicatecrash工具符号化崩溃日志: ./symbolicatecrash .crash文件 .dsym文件 > xxx.log 

③根据奔溃位置地址信息找到指定位置:dwarfdump--lookup 0x000cf358 --arch armv7 appname.app.dSYM/

好吧,这个流程的3步是个人复制粘贴来的,关键是定位不正确,感觉有点坑,也可能是个人流程错误。所以暂时还是使用无dsym文件的路程方案,之后可能还会来补下这里内容。

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

推荐阅读更多精彩内容

  • 什么是崩溃日志 iOS的App在崩溃时,系统会记录下当前的每个线程的调用栈信息等等,并保存到设备中。这些信息汇总起...
    handyTOOL阅读 3,926评论 0 12
  • 作为一名自认为很牛逼的程序员,当你发现bug时你的内心世界是这样的: 当你定位到bug,并花了一晚上把它改好,发现...
    穿山甲救蛇精阅读 12,822评论 10 74
  • 补充2个概念(来源掘金翻译): 什么是 dSYM 文件 Xcode编译项目后,我们会看到一个同名的 dSYM 文件...
    蜡笔小强阅读 649评论 2 5
  • 我是06年11月开的公众号,名字叫江南可采莲莲叶何田田,当时是因为个人的独特经历,很想在那年的感恩节发一些个人已经...
    四月槐花香阅读 242评论 0 0
  • 本文与网络请求框架那篇文章大致类似,但封装的更为完善,介绍的也更详细,在项目中所有用到的网络请求都需要该类参与。 ...
    隰有荷阅读 459评论 0 1