11

我最近为我的应用程序推送了 iOS 7 更新,并在启用崩溃报告的情况下实现了 Flurry Analytics。我最近注意到一些用户遇到了崩溃。使用 Flurry,我可以在我的应用程序崩溃时检索堆栈跟踪以追踪问题。
好吧,我当然熟悉崩溃报告,并且之前已经通过从 iTunes Connect 或邮件获取它们并在 Xcode 中简单地对它们进行符号化来修复使用它们的错误。然而,我没有成功地使用 Flurry 做到这一点。

我尝试了什么:
当查看 Flurry 本身的堆栈跟踪时,我得到了: Flurry 堆栈跟踪 正如你所看到的,很多行都被完美地符号化了,其他的被符号化为<redacted>. 一些研究告诉我,Apple 在 iOS 6 和 7 中删除了很多调试符号。
我尝试的第一件事是上传我自己的 dSYM 文件。Flurry 报告 dSYM 文件已保存,并且崩溃报告再次使用 dSYM 文件进行符号化。然而,堆栈跟踪仍然与没有 dSYM 的情况完全相同。
没问题,我想,我可以尝试下载崩溃报告并使用 Xcode 对其进行符号化。单击下载会给我一个文件(没有扩展名,因此我将其重命名为.crash),其中包含以下内容:

Hardware Model:      iPhone3,1
Process:         RadioPlayer [2965]
Path:            /var/mobile/Applications/E4DD7DA6-4450-4538-A1E2-AE23139FAC10/RadioPlayer.app/RadioPlayer
Identifier:      *******
Version:         1.2.0
Code Type:       ARM
Parent Process:  launchd [1]

Exception Type:  SIGSEGV
Exception Codes: SEGV_ACCERR at 0x548a000
Crashed Thread:  2

Thread 0:
0   libsystem_kernel.dylib              0x3aa67a8c _mach_msg_trap + 20
1   CoreFoundation                      0x3015e7cb <redacted> + 154
2   CoreFoundation                      0x3015cf37 <redacted> + 854
3   CoreFoundation                      0x300c7ce7 _CFRunLoopRunSpecific + 522
4   CoreFoundation                      0x300c7acb _CFRunLoopRunInMode + 106
5   GraphicsServices                    0x34da0283 _GSEventRunModal + 138
6   UIKit                               0x32969a41 _UIApplicationMain + 1136
7   RadioPlayer                         0x000dfb9b __mh_execute_header + 23451
8   libdyld.dylib                       0x3a9c3ab7 <redacted> + 2

Thread 1:
0   libsystem_kernel.dylib              0x3aa6783c _kevent64 + 24
1   libdispatch.dylib                   0x3a9a23f3 <redacted> + 38

Thread 2 Crashed:
0   vImage                              0x2f19d7dc <redacted> + 139
1   vImage                              0x2f1874ff _vImageFlatten_RGBA8888 + 378
2   vImage                              0x2f26e799 <redacted> + 40
3   vImage                              0x2f27d7c3 <redacted> + 674
4   vImage                              0x2f27d365 _vImageConvert_AnyToAny + 1300
5   ImageIO                             0x30efd9e7 <redacted> + 858
6   ImageIO                             0x30ef8c3b <redacted> + 2754
7   ImageIO                             0x30ef8173 <redacted> + 102
8   ImageIO                             0x30ef8057 _CGImageDestinationFinalize + 66
9   UIKit                               0x32a8a611 _UIImageJPEGRepresentation + 520
10  MediaPlayer                         0x31435319 -[MPMediaItemArtwork imageDataWithSize:atPlaybackTime:] + 36
11  MediaPlayer                         0x31435387 -[MPMediaItemArtwork albumImageDataWithSize:] + 42
12  MediaPlayer                         0x31494f0d -[MPNowPlayingInfoCenter _pushNowPlayingInfoAndRetry:] + 824
13  libdispatch.dylib                   0x3a99ed7b <redacted> + 10
14  libdispatch.dylib                   0x3a99f2f3 <redacted> + 378
15  libdispatch.dylib                   0x3a99f75b <redacted> + 38
16  libdispatch.dylib                   0x3a9b18f9 <redacted> + 76
17  libdispatch.dylib                   0x3a9b1b79 <redacted> + 56
18  libsystem_pthread.dylib             0x3aae0dbf __pthread_wqthread + 298
19  libsystem_pthread.dylib             0x3aae0c84 _start_wqthread + 8


// The file continues like this listing the other threads and overview of binary images.
// I however didn't paste that part here since I don't think it's useful.

我现在尝试简单地将这个文件拖到 Xcode 管理器中并导入设备日志。两者都没有做任何事情。列表中没有出现新的设备日志或其他任何内容。
下一步:尝试使用atos. 我将 dSYM 的内容复制到工作目录等,然后尝试了这个命令

xcrun atos -arch armv7 -o RadioPlayer 0x31435387`

这回来了0x31435387。我尝试了其他一些内存地址,每次输出都是内存地址本身。

有人可以帮我解决这个问题吗?我真的很想象征这些<redacted>符号,因为它肯定会帮助我修复导致这些崩溃的错误。谢谢!

4

3 回答 3

10

我注意到,为了能够将 Flurry 崩溃报告拖到 XCode Organizer,您需要:

  1. 将文件重命名为 .crash
  2. 在报告顶部添加事件标识符行。这看起来像一个 GUID,因此您可以放置​​任何独特的东西或在线生成一个,例如

    事件标识符:D1D6CA1F-EC87-4677-9366-401BE050B2C8

  3. 添加 iOS 和崩溃报告版本行(就在异常类型上方),例如

    操作系统版本:iOS 7.1.1 (11D201)

    报告版本:104

于 2014-05-26T14:04:50.150 回答
6
  1. <redacted>是仅针对系统符号的 iOS 优化。
  2. 上传您的应用程序 dSYM 不会改变任何事情,因为它只包含应用程序符号,而不是所需 cpu 架构的 iOS 系统符号。
  3. 要在本地对它们进行符号化,您需要具有确切的系统符号或导致崩溃的 iOS 版本和体系结构。
  4. 使用atos您的应用程序二进制/dSYM 来表示系统符号不起作用(如上所述)
  5. 只传入栈帧中的地址来获取符号,永远行不通,还需要传入对应二进制文件的加载地址(可以在二进制图片部分找到,二进制文件的行首地址)
  6. 在您的atos示例中,您正在尝试一个已经在堆栈跟踪中显示正确符号的地址。
  7. 如果您有可用的符号,则将崩溃报告拖到 Xcode 管理器中应该已经象征了报告,并且您不必执行手动步骤。
  8. 看起来 Flurry 在他们的服务器上没有 iOS 符号来自己解析这些符号。

所以图书馆的一个例子0x3a99ed7b是:libdispatch.dylib

xcrun atos -arch armv7 -o PathToLibrary -l LoadAddressOfLibrary 0x3a99ed7b

Mac 上 iOS 符号的根路径是:~/Library/Developer/Xcode/iOS DeviceSupport/`,每个 iOS 版本都有一个子目录。

所以简单的解决方案:将崩溃报告拖到Device LogsXcode 管理器中的条目中,希望您拥有所需的一切。如果这至少没有删除一些<redacted>字符串,则您缺少 iOS 符号,并且手动步骤也不起作用。

于 2013-11-06T15:29:26.737 回答
1

这适用于我的混乱日志http://ipartymobile.com/how-to-find-your-bug-from-ios-crash-logs/ 不必在崩溃报告中添加任何内容,只需获取内存地址并插入到这种格式“xcrun atos -arch armv7 -o MyApp 0x0000000”

于 2015-11-20T20:06:03.590 回答