为什么我的堆栈跟踪只有在调试器附加时才包含行号?

5

我有一个使用Xamarin.Android开发的应用程序,会向Raygun报告崩溃情况。从发布版本报告给Raygun的堆栈跟踪信息不包括行号。如果我在.csproj文件中将发布版本的设置与调试配置相同,则可以解决此问题:

<PropertyGroup Condition=" '$(Configuration)|$(Platform)' == 'Release|AnyCPU' ">
  <DebugSymbols>True</DebugSymbols>
  <DebugType>full</DebugType>
  <Optimize>false</Optimize>
  ...
</PropertyGroup>

然后我仍然看不到发送到Raygun的堆栈跟踪中的行号。但是,如果我使用Visual Studio调试程序运行应用程序,则发送到Raygun的堆栈跟踪将包括行号。请注意,所有堆栈跟踪在任何情况下都包括类和方法名称。这个问题只关心行号。
为什么只有在抛出异常时附加调试器时,堆栈跟踪才包括行号?更重要的是,如何在Release版本的报告的堆栈跟踪中获取行号而不需要附加调试器?
1个回答

9
您需要使用发布版本的符号(构建的 msym 和构建应用程序必须来自同一个构建)通过 mono-symbolicate 来将“原生”Android崩溃报告进行符号化。一些崩溃报告服务直接支持Xamarin,并允许您上传构建的 msym 文件并自动运行mono-symbolicate,而其他一些则不支持,因此需要您手动完成(或者一些支持Web钩子,您可以自己实现每个收到的崩溃报告运行它,在Fabric上我是这样做的)。
mono-symbolicate
Usage: symbolicate [options] <msym dir> <input file>
       symbolicate [options] store-symbols <msym dir> [<dir>]+

Available options:
  -h, --help                 Show this help
  -q                         Quiet, warnings are not displayed
  -v                         Verbose, log debug messages

接下来,获取一个未处理异常的崩溃日志

adb logcat -d > errors.txt

最后,使用mono-symbolicate将错误转换为包含文件和行号的格式:
mono-symbolicate path-to-dll-in-.mSYM-directory path-to-errors.txt

例如,给定一个包含以下内容的errors.txt文件:
I/MonoDroid( 1545): System.Exception: wow it broke
I/MonoDroid( 1545):   at CrashApp.MainActivity+<OnCreate>c__AnonStorey0.<>m__0 (System.Object , System.EventArgs ) [0x00030] in <filename unknown>:0
I/MonoDroid( 1545):   at Android.Views.View+IOnClickListenerImplementor.OnClick (Android.Views.View v) [0x00014] in <filename unknown>:0
I/MonoDroid( 1545):   at Android.Views.View+IOnClickListenerInvoker.n_OnClick_Landroid_view_View_ (IntPtr jnienv, IntPtr native__this, IntPtr native_v) [0x00011] in <filename unknown>:0
I/MonoDroid( 1545):   at (wrapper dynamic-method) System.Object:5616285d-461b-4005-a31b-d4637a8cdddc (intptr,intptr,intptr)

mono-symbolicate将把上述内容翻译成:
I/MonoDroid( 1545): System.Exception: wow it broke
I/MonoDroid( 1545):   at CrashApp.MainActivity+<OnCreate>c__AnonStorey0.<>m__0 (System.Object , System.EventArgs ) [0x00030] in /Users/dean/Projects/CrashApp/CrashApp/MainActivity.cs:30
I/MonoDroid( 1545):   at Android.Views.View+IOnClickListenerImplementor.OnClick (Android.Views.View v) [0x00014] in /Users/dean/Documents/Sandbox/Xamarin/dellismonodroid/src/Mono.Android/platforms/android-19/src/generated/Android.Webkit.WebBackForwardList.cs:68
I/MonoDroid( 1545):   at Android.Views.View+IOnClickListenerInvoker.n_OnClick_Landroid_view_View_ (IntPtr jnienv, IntPtr native__this, IntPtr native_v) [0x00011] in /Users/dean/Documents/Sandbox/Xamarin/dellismonodroid/src/Mono.Android/platforms/android-19/src/generated/Android.Webkit.WebBackForwardList.cs:23
I/MonoDroid( 1545):   at (wrapper dynamic-method) System.Object:5616285d-461b-4005-a31b-d4637a8cdddc (intptr,intptr,intptr)

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接