Crash日志符号化

1.符号化crash日志需要3样东西:

1).crash日志本身(如:example.crash),从Xcode的organizer导出或者来自Itunes Connect.

2).crash日志所对应的.app包(如:example.app)如果你有的是.ipa包,你可以解压后在Payload/文件夹下获得.app包

3).crash日志多对应的.dSYM包

 

2.开始符号化之前,先检查一下以上3样东西是否相对应(UUID):

crash日志中可以看到类似一下内容:

...
Binary Images: 0xe1000 - 0x1f0fff +example armv7 <aa5e633efda8346cab92b01320043dc3> /var/mobile/Applications/9FB5D11F-42C0-42CA-A336-4B99FF97708F/example.app/example 0x2febf000 - 0x2fedffff dyld armv7s <4047d926f58e36b98da92ab7a93a8aaf> /usr/lib/dyld ...

 说明,这个二进制镜像名为 example.app/example,UUID为 aa5e633efda8346cab92b01320043dc3 .

 可以用以下命令检查.app的UUID:

dwarfdump --uuid example.app/example UUID: AA5E633E-FDA8-346C-AB92-B01320043DC3 (armv7) example.app/example

 检查.dSYM文件的UUID:

dwarfdump --uuid example.app.dSYM UUID: AA5E633E-FDA8-346C-AB92-B01320043DC3 (armv7) example.app.dSYM/Contents/Resources/DWARF/example

 

3.使用symbolicatecrash脚本

如果是Xcode 6.1,使用:

/Applications/Xcode.app/Contents/SharedFrameworks/DTDeviceKitBase.framework/Versions/A/Resources/symbolicatecrash -v example.crash 2> symbolicate.log

如果找不到该脚本,使用:

find . -name symbolicatecrash

用终端查找和crash日志中的uuid一只的符号文件:

mdfind "com_apple_xcode_dsym_uuids == AA5E633E-FDA8-346C-AB92-B01320043DC3"

如果遇到 "DEVELOPER_DIR" is not defined 的报错,执行以下命令:

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

 

2.使用终端符号化日志:

xcrun atos -o MyApp.app/MyApp -arch armv7 -l 0xb7000 -f MyApp.crash

其中0xb7000就是crash日子中紧跟"Binary Images:"后面的地址

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值