我有一个用C++编写的node.js模块,它为C++库提供了一些绑定。由于SIGSEGV,这个库崩溃了,所以我需要用GDB对它进行调试,找出哪里出了问题。
我在./node_modules/somelib/
中已经有了模块的源代码,如果我转到那个文件夹并输入npm install
,这个库就被编译了,并且可以通过node.js中的一个require('somelib')来使用。我可以将gdb附加到节点并重现错误,但在堆栈跟踪中我只能看到node_modules/somelib/Release/somelib.node
。
我不确定这是否重要,但是这个库是使用node-gyp
编译的。
node-gyp
以生成调试符号?发布于 2014-04-23 05:04:57
我刚刚在node-gyp
文档中找到了这个问题的答案。解决方案是使用--debug
标志调用构建过程。这意味着调用node-gyp configure --debug
和/或node-gyp build --debug
。然后,将创建Debug
文件夹,而不是Release
文件夹。然后gdb会自动加载源文件。
发布于 2018-10-11 23:00:37
厚颜无耻地从 复制了@Peter Cordes提供的链接(现已损坏)
首先,使用node-gyp和--debug标志编译您的附加组件。
$ node-gyp --debug configure rebuild
其次,如果您仍然像我一样处于“游乐场”模式,那么您可能正在使用如下内容加载您的模块
var ObjModule = require('./ObjModule/build/Release/objModule');
但是,当您在调试模式下使用node-gyp进行重新构建时,node-gyp会丢弃发布版本,而创建一个调试版本。所以更新模块路径:
var ObjModule = require('./ObjModule/build/Debug/objModule');
好了,现在我们准备好调试我们的C++插件了。对节点二进制文件运行gdb,这是一个C++应用程序。现在,节点本身并不知道您的附加组件,所以当您尝试在附加组件函数(在本例中为StringReverse)上设置断点时,它会报告没有定义特定的函数。不用担心,您的附加组件是它所指的“未来共享库加载”的一部分,一旦您在JavaScript中请求()您的附加组件,它就会被加载。
$ gdb node
...
Reading symbols from node...done.
(gdb) break StringReverse
Function "StringReverse" not defined.
Make breakpoint pending on future shared library load? (y or [n]) y
好了,现在我们只需要运行应用程序:
(gdb) run ../modTest.js
...
Breakpoint 1, StringReverse (args=...) at ../objModule.cpp:49
发布于 2014-04-23 03:54:25
您可以将包含模块源代码的目录添加到gdb的搜索路径中:
(gdb) directory /path/to/source
请参阅:http://sourceware.org/gdb/onlinedocs/gdb/Source-Path.html
此外,要获取node-gyp
调试符号,请安装node-gyp-dbg/dev
或等效程序,或使用-g
编译它
https://stackoverflow.com/questions/23228868
复制相似问题