iOS崩溃日志解析脚本

浅谈iOS日志收集系统中介绍了如何收集iOS崩溃日志与如何解析iOS崩溃日志,主要用到了两个工具:

  • plcrashutil:将plcrash文件转换成苹果标准崩溃格式
  • symbolicatecrash:符号化崩溃信息 结合这两个工具写了一个脚本直接将.plcrash格式的文件符号化解析,并输出到控制台与本地文件。
    主要是根据.plcrash文件中的uuid来匹配出本地默认Archive路径下对应的dSYM文件。或者传入对应奔溃日志的dSYM文件直接解析。

对应的shell脚本如下

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
#!/bin/bash
if [ $# -lt 1 ] || [ $# -gt 2 ]; then
echo "Warning!!! formate: './lanalyseCrash.sh {crash path} {dSYMs path}"
echo "Default Path ~/Library/Developer/Xcode/Archives/*"
exit
fi

./plcrashutil convert --format=iphone $1 > temp.crash
temp="temp.crash"
archive=""
archiveDir=~/Library/Developer/Xcode/Archives/*/*/dSYMs/*

if [ $# -eq 2 ]; then
archive=$2
archiveDir=""
fi


crashFile=`cat temp.crash`

log=`sed -n '/JobHunter.*<.*>/p' temp.crash`
cutLog=`echo $log | egrep -o "<.*>"`
cutLog=`echo ${cutLog%>*}`
cutLog=`echo ${cutLog#*<}`
uid=`echo $cutLog | tr "[a-z]" "[A-Z]"`
uid=`echo ${uid:0:8}-${uid:8:4}-${uid:12:4}-${uid:16:4}-${uid:20:12}`
patten="\.*"${uid}"\.*"
for archiveFile in $archiveDir; do
result=`dwarfdump --uuid "${archiveFile}"`
if [[ $result =~ $patten ]]; then
archive=$archiveFile
break
fi
done

if [[ -z $archive ]]; then
echo "not exist archive file Path!"
rm -r temp.crash
exit
fi
# echo $archive
export DEVELOPER_DIR=/Applications/Xcode.app/Contents/Developer
logTime=$(date "+%Y%m%d%H%M%S")
./symbolicatecrash temp.crash $archive > ${logTime}.log
cat ${logTime}.log
rm -r temp.crash

使用方法:

  1. 将上面代码拷贝到lanalysecrash.sh文件中。并给lanalysecrash.sh添加可执行权限。
  2. plcrashutilsymbolicatecrashlanalysecrash.sh放在同一目录下。
  3. 进入该目录下执行以下命令
    1
    ./lanalysecrash.sh 1501155667.plcrash


1
./lanalysecrash.sh 1501155667.plcrash Demo.app.dSYM

如果不传dSYM文件的路径那么默认会从~/Library/Developer/Xcode/Archives/*下查找对应的dSYM文件。

执行结束后会在该目录下生成一个log日志文件,同时会在bash控制台输出改日志内容。