跳转至主要内容

在调试器中设置符号服务器

调试符号能让你有更好的调试体验。它们包含可执行文件和动态库中的函数信息,并为你提供获取清晰调用堆栈的信息。符号服务器允许调试器自动加载正确的符号、二进制文件和源代码,而无需用户下载大型调试文件。该服务器的功能类似于微软的符号服务器,因此那里的文档可能很有用。

请注意,由于发布的 Electron 版本经过了大量优化,调试并不总是容易的。调试器将无法显示所有变量的内容,并且由于内联、尾调用和其他编译器优化,执行路径可能看起来很奇怪。唯一的解决方法是构建一个未优化的本地版本。

Electron 的官方符号服务器 URL 是 https://symbols.electronjs.org。你不能直接访问此 URL,必须将其添加到调试工具的符号路径中。在下面的示例中,使用本地缓存目录来避免重复从服务器获取 PDB。将 c:\code\symbols 替换为你机器上合适的缓存目录。

在 Windbg 中使用符号服务器

Windbg 符号路径是用星号字符分隔的字符串值配置的。要仅使用 Electron 符号服务器,请将以下条目添加到你的符号路径(注意:你可以将 c:\code\symbols 替换为你计算机上任何可写的目录,如果你希望将下载的符号放在不同的位置)

SRV*c:\code\symbols\*https://symbols.electronjs.org

使用 Windbg 菜单或键入 .sympath 命令,将此字符串设置为环境中的 _NT_SYMBOL_PATH。如果你还想从微软的符号服务器获取符号,你应该先列出它

SRV*c:\code\symbols\*https://msdl.microsoft.com/download/symbols;SRV*c:\code\symbols\*https://symbols.electronjs.org

在 Visual Studio 中使用符号服务器

Tools -> Options

Symbols Settings

故障排除:符号未加载

在 Windbg 中键入以下命令以打印符号未加载的原因

> !sym noisy
> .reload /f electron.exe