跳到主要内容
新架构实战课 实操 + 基建 + 原理全维度包揽,抢先掌握 React Native 新架构精髓 立即查看 >Version: Next

Debugging Release Builds

符号化堆栈跟踪

在发布版本中,React Native 应用如果触发了未处理的异常,其输出可能会被混淆并且难以阅读。

07-15 10:58:25.820 18979 18998 E AndroidRuntime: FATAL EXCEPTION: mqt_native_modules
07-15 10:58:25.820 18979 18998 E AndroidRuntime: Process: com.awesomeproject, PID: 18979 07-15 10:58:25.820 18979 18998 E AndroidRuntime: com.facebook.react.common.JavascriptException: Failed, js engine: hermes, stack:
07-15 10:58:25.820 18979 18998 E AndroidRuntime: p@1:132161
07-15 10:58:25.820 18979 18998 E AndroidRuntime: p@1:132084
07-15 10:58:25.820 18979 18998 E AndroidRuntime: f@1:131854
07-15 10:58:25.820 18979 18998 E AndroidRuntime: anonymous@1:131119

在上述堆栈跟踪中,类似p@1:132161的条目是经过压缩的函数名称和字节码偏移量。为了调试这些调用,我们希望将它们转换为文件、行和函数名称,例如AwesomeProject/App.js:54:initializeMap。这被称为符号化

您可以通过将堆栈跟踪和生成的源映射传递给metro-symbolicate来对上述类似的经过压缩的函数名称和字节码进行符号化。

启用源映射(source map)

源映射是符号化堆栈跟踪所必需的。请确保在目标平台的构建配置中启用了源映射。

info

在 Android 上,默认情况下已经启用了源映射。

要启用源映射生成,请确保在 android/app/build.gradle 中包含以下 hermesFlags

react {
hermesFlags = ["-O", "-output-source-map"]
}

如果操作正确,您应该在 Metro 构建输出期间看到源映射的输出位置。

Writing bundle output to:, android/app/build/generated/assets/react/release/index.android.bundle
Writing sourcemap output to:, android/app/build/intermediates/sourcemaps/react/release/index.android.bundle.packager.map

使用 metro-symbolicate

有了生成的源映射,现在可以翻译我们的堆栈跟踪了。

# 打印使用说明
npx metro-symbolicate

# 从包含堆栈跟踪的文件中
npx metro-symbolicate android/app/build/generated/sourcemaps/react/release/index.android.bundle.map < stacktrace.txt

# 从 adb logcat(Android)
adb logcat -d | npx metro-symbolicate android/app/build/generated/sourcemaps/react/release/index.android.bundle.map

源映射注意事项

  • 构建过程可能会生成多个源映射。确保使用示例中显示的位置的源映射。
  • 确保您使用的源映射对应于崩溃应用的确切提交。源代码的小改动可能导致偏移的巨大差异。
  • 如果 metro-symbolicate 立即成功退出,请确保输入来自管道或重定向,而不是终端。