在做这个项目时,一开始并未考虑收集用户的崩溃日志,都是由用户直接反馈崩溃问题给客服或是产品经理,然后再交于开发进行修复,掩面,好菜喔~
于是询问了几个朋友,平安证券和我是大美人,采用的是Crashlytics,365好睡眠采用的是bugly,友公司魔库采用的是友盟的SDK,再查查资料,于是决定选用Crashlytics.
由于自己英文好菜,最开始的导入,先查了一堆资料,到真正导入成功,才发现其实很简单,只需要注册一个Fabric的账号,下载客户端,按照客户端的指引操作,十分简单就可以集成了。
唯一需要注意的是,如果使用了友盟的shareSDK,那么集成Crashlytics,会出现如下错误:
网上给出的答案是:
问题在于友盟的Twitter中内嵌了低版本的fabric, 和Crashlytics冲突了 需要手动导入友盟分享的sdk。
Crashlytics使用十分简单和方便,而且上传了dSYM符号集,可以准确的定位到崩溃在哪一行,十分欣喜~~~
关于dSYM符号集
进行崩溃分析,首先要弄懂一个概念,就是符号集。
符号集是我们对ipa文件进行打包之后,和.app文件同级的后缀名为.dSYM的文件,这个文件必须使用Xcode进行打包才有。
每一个.dSYM文件都有一个UUID,和.app文件中的UUID对应,代表着是一个应用。而.dSYM文件中每一条崩溃信息也有一个单独的UUID,用来和程序的UUID进行校对。
我们如果不使用.dSYM文件获取到的崩溃信息都是不准确的。
符号集中存储着文件名、方法名、行号的信息,是和可执行文件的16进制函数地址对应的,通过分析崩溃的.Crash文件可以准确知道具体的崩溃信息。
我们每次Archive一个包之后,都会随之生成一个dSYM文件。每次发布一个版本,我们都需要备份这个文件,以方便以后的调试。进行崩溃信息符号化的时候,必须使用当前应用打包的电脑所生成的dSYM文件,其他电脑生成的文件可能会导致分析不准确的问题。
当程序崩溃的时候,我们可以获得到崩溃的错误堆栈,但是这个错误堆栈都是0x开头的16进制地址,需要我们使用Xcode自带的symbolicatecrash工具来将.Crash和.dSYM文件进行符号化,就可以得到详细崩溃的信息。
崩溃分析
命令行解析Crash文件
通过Mac自带的命令行工具解析Crash文件需要具备三个文件
symbolicatecrash,Xcode自带的崩溃分析工具,使用这个工具可以更精确的定位崩溃所在的位置,将0x开头的地址替换为响应的代码和具体行数。
我们打包时产生的dSYM文件。
崩溃时产生的Crash文件。
我在解析崩溃信息的时候,首先在桌面上建立一个Crash文件夹,然后将.Crash、.dSYM、symbolicatecrash放在这个文件夹中,这样进入这个文件夹下,直接一行命令就解决了。
symbolicatecrash我们可以在下面路径下可以找到,我用的是Xcode7,其他版本Xcode路径不一样,请自行Google。
1
/Applications/Xcode.app/Contents/SharedFrameworks/DTDeviceKitBase.framework/Versions/A/Resources/symbolicatecrash
然后Window->Organizer->Archives中,选中archive的版本右击,选择Show in Finder就可以获取dSYM文件了。
dSYM文件
将.Crash、.dSYM、symbolicatecrash三个文件都放在我们在桌面建立的Crash文件夹中。
Crash文件夹
开启命令行工具,进入崩溃文件夹中
cd /Users/username/Desktop/崩溃文件夹
使用命令解析Crash文件
./symbolicatecrash ./.crash ./.app.dSYM > symbol.crash
如果上面命令不成功,使用命令检查一下环境变量
xcode-select -print-path
返回结果:
/Applications/Xcode.app/Contents/Developer/
如果不是上面的结果,需要使用下面命令设置一下导出的环境变量,然后重复上面解析的操作。
export DEVELOPER_DIR=/Applications/XCode.app/Contents/Developer
解析完成后会生成一个新的.Crash文件,这个文件中就是崩溃详细信息。图中红色标注的部分就是我们代码崩溃的部分。
解析完成的结果
注意,以下情况不会有崩溃信息产生:
内存访问错误(不是野指针错误)
低内存,当程序内存使用过多会造成系统低内存的问题,系统会将程序内存回收
因为某种原因触发看门狗机制
通过Xcode查看设备崩溃信息
除了上面的系统分析工具来进行分析,如果是我们自己直接使用手机连接崩溃或者崩溃之后连接手机,选择window-> devices -> 选择自己的手机 -> view device logs 就可以查看我们的崩溃信息了。
view device logs
只要手机上的应用是这台电脑安装打包的,这样的崩溃信息系统已经为我们符号化好了,我们只需要进去之后等一会就行(不要相信这里面的进度刷新,并不准确),如果还是没有符号化完毕 ,我们选择文件,然后右击选择Re-Sysbomlicate就可以。
如果是使用其他电脑进行的打包,我们可以在这里面将Crash文件导出,自己通过命令行的方式进行解析。