戴铭(iOS开发课)读书笔记:12章节-崩溃监控

原文链接:iOS 崩溃千奇百怪,如何全面监控?


一、编码常见崩溃

1 数组越界
2 多线程问题
3 程序无响应
4 野指针

二、捕获崩溃问题

1 可捕获的崩溃信号

KVO、Notification线程问题、数组越界、野指针

收集这些崩溃日志的常用方法:
1 Xcode -> Archive
2 PLCrashReporter 获取崩溃日志,上传到自己的服务器查看
3 Fabric
4 Bugly

捕获原理:

程序发生崩溃时,我们经常会看到这段代码:

Exception Type:        EXC_BAD_ACCESS (SIGSEGV)

它表示,EXC_BAD_ACCESS这个异常会通过SIGSEGV信号发现问题。

可以通过 signalHandler 来捕获不同种类的信号,代码如下:

void registerSignalHandler(void) {
    signal(SIGSEGV, handleSignalException);
    signal(SIGFPE, handleSignalException);
    signal(SIGBUS, handleSignalException);
    signal(SIGPIPE, handleSignalException);
    signal(SIGHUP, handleSignalException);
    signal(SIGINT, handleSignalException);
    signal(SIGQUIT, handleSignalException);
    signal(SIGABRT, handleSignalException);
    signal(SIGILL, handleSignalException);
}

void handleSignalException(int signal) {
    NSMutableString *crashString = [[NSMutableString alloc]init];
    void* callstack[128];
    int i, frames = backtrace(callstack, 128);
    char** traceChar = backtrace_symbols(callstack, frames);
    for (i = 0; i <frames; ++i) {
        [crashString appendFormat:@"%s\n", traceChar[i]];
    }
    NSLog(crashString);
}

上面这段代码对各种信号都进行了注册,捕获到异常信号后,在处理方法 handleSignalException 里通过 backtrace_symbols 方法就能获取到当前的堆栈信息。
在程序崩溃前,将错误的堆栈信息保存在本地磁盘中,下次启动时再上传到服务器。

2 不可捕获的崩溃信号

后台任务超时、内存打爆、主线程卡顿超阈值

App 退到后台中,即使代码逻辑没有问题也很容易出现崩溃,这些崩溃往往是因为系统强制杀掉了某些进程导致的,导致强杀的信号还由于系统限制无法被捕获到。

后台容易崩溃的原因是什么?
iOS后台保活的方式有5种:Background Mode、Background Fetch、Silent Push、PushKit、Background Task。

每种方式都有不同的使用场景,这里就不一一介绍了,感兴趣的朋友可以自己去了解一下。
这5种方式中,Background Task最为常用,App退到后台后,默认都会使用这种方式。

通过UIApplication的beginBackgroundTaskWithExpirationHandler:保持程序在后台运行

我们必须知道的是,App进入后台后,你的任务最终执行的时间是有限的。(这个时间具体是多少没有被考证,戴老师原文中说是3分钟,上面提供的截图中说的是10分钟,截图来自《iOS高级编程》)
总之,在有限的时间内没有执行完任务,系统也会强制杀掉进程。而后台处理的任务分门别类,所以很容易出现崩溃。尤其是要控制后台读写操作

如何监控内存打爆、主线程卡顿超阈值?
内存打爆和主线程卡顿超过阈值被 watchdog 杀掉这两种情况也会造成程序崩溃。
监控他们的思路和监控后台崩溃类似,我们要先找到它们的阈值,然后在临近阈值时还在执行的后台程序判断为将要崩溃,收集信息并上报。(关于内存和卡顿阈值怎么获取和RunLoop有关,后面会介绍)

三、分析和解决崩溃问题

对于捕获的系统的崩溃日志,主要包含的信息为:进程信息、基本信息、异常信息、线程回溯。

  • 进程信息:崩溃进程的相关信息,比如崩溃报告唯一标识符、唯一键值、设备标识
  • 基本信息:崩溃发生的日期、iOS版本
  • 异常信息:异常类型、异常编码、异常的线程
  • 线程回溯:崩溃时的方法调用栈

方法1: 查看方法调用栈
先通过异常信息分析出发生异常的线程,然后分析方法调用栈,符号化后的方法调用栈可以完整的看到方法调用的过程,从而知道问题发生在哪个方法的调用上。

栈顶的方法就是最后导致崩溃的方法调用。

方法2: 分析异常编码
一些被系统杀掉的情况,我们可以通过异常编码来分析。
这里举例3种常见的异常编码:

  • 0x8badf00d,表示 App 在一定时间内无响应二倍 watchdog 杀掉
  • 0xdeadfa11,表示 App 被用户强制退出
  • 0xc00010ff,表示 App 因为运行造成设备温度太高而被杀掉

方法3: 分析第三方平台采集的崩溃信息
之前我们提到的向 Bugly 平台,在监控到崩溃信息后,它们会提供可视化的信息来辅助我们追溯问题。

最后

解决线上崩溃问题是一个非常复杂且繁琐的工作,由于我个人在这方面也没有很丰富的经验,所以此篇文章仅做学习和了解。

虽说现在可以使用的第三方监控平台很多,但是有些错误发生后难以定位和复现。解决崩溃问题涉及的知识也远不止这些,除了上文的内容,可能还涉及 RunLoop 的相关知识、App对设备性能及电量的影响、App 的全量日志信息等知识。

太多内容导致我无法去一一实践和测试,做技术就是要不断的学习,希望自己能坚持。

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

推荐阅读更多精彩内容