2012-02-27 20:08:17 +01:00
|
|
|
# Debugger
|
|
|
|
|
2016-07-16 00:35:38 +02:00
|
|
|
> Stability: 2 - Stable
|
2012-03-03 00:14:03 +01:00
|
|
|
|
2012-02-27 20:44:30 +01:00
|
|
|
<!-- type=misc -->
|
2010-12-31 03:46:49 +01:00
|
|
|
|
2015-12-27 06:19:35 +01:00
|
|
|
Node.js includes a full-featured out-of-process debugging utility accessible
|
|
|
|
via a simple [TCP-based protocol][] and built-in debugging client. To use it,
|
|
|
|
start Node.js with the `debug` argument followed by the path to the script to
|
|
|
|
debug; a prompt will be displayed indicating successful launch of the debugger:
|
2010-12-31 03:46:49 +01:00
|
|
|
|
2016-07-09 07:13:09 +02:00
|
|
|
```txt
|
2016-01-21 23:21:22 +01:00
|
|
|
$ node debug myscript.js
|
2016-01-17 18:39:07 +01:00
|
|
|
< debugger listening on port 5858
|
|
|
|
connecting... ok
|
|
|
|
break in /home/indutny/Code/git/indutny/myscript.js:1
|
|
|
|
1 x = 5;
|
2016-01-24 10:15:51 +01:00
|
|
|
2 setTimeout(() => {
|
2016-01-17 18:39:07 +01:00
|
|
|
3 debugger;
|
|
|
|
debug>
|
|
|
|
```
|
2010-12-31 03:46:49 +01:00
|
|
|
|
2016-05-27 01:35:23 +02:00
|
|
|
Node.js's debugger client is not a full-featured debugger, but simple step and
|
|
|
|
inspection are possible.
|
2010-12-31 03:46:49 +01:00
|
|
|
|
2015-12-27 06:19:35 +01:00
|
|
|
Inserting the statement `debugger;` into the source code of a script will
|
2016-05-27 01:35:23 +02:00
|
|
|
enable a breakpoint at that position in the code:
|
2010-12-31 03:46:49 +01:00
|
|
|
|
2016-01-17 18:39:07 +01:00
|
|
|
```js
|
|
|
|
// myscript.js
|
|
|
|
x = 5;
|
2016-01-24 10:15:51 +01:00
|
|
|
setTimeout(() => {
|
2016-01-17 18:39:07 +01:00
|
|
|
debugger;
|
|
|
|
console.log('world');
|
|
|
|
}, 1000);
|
|
|
|
console.log('hello');
|
|
|
|
```
|
2010-12-31 03:46:49 +01:00
|
|
|
|
2015-12-27 06:19:35 +01:00
|
|
|
Once the debugger is run, a breakpoint will occur at line 4:
|
2010-12-31 03:46:49 +01:00
|
|
|
|
2016-07-09 07:13:09 +02:00
|
|
|
```txt
|
2016-01-21 23:21:22 +01:00
|
|
|
$ node debug myscript.js
|
2016-01-17 18:39:07 +01:00
|
|
|
< debugger listening on port 5858
|
|
|
|
connecting... ok
|
|
|
|
break in /home/indutny/Code/git/indutny/myscript.js:1
|
|
|
|
1 x = 5;
|
2016-01-24 10:15:51 +01:00
|
|
|
2 setTimeout(() => {
|
2016-01-17 18:39:07 +01:00
|
|
|
3 debugger;
|
|
|
|
debug> cont
|
|
|
|
< hello
|
|
|
|
break in /home/indutny/Code/git/indutny/myscript.js:3
|
|
|
|
1 x = 5;
|
2016-01-24 10:15:51 +01:00
|
|
|
2 setTimeout(() => {
|
2016-01-17 18:39:07 +01:00
|
|
|
3 debugger;
|
|
|
|
4 console.log('world');
|
|
|
|
5 }, 1000);
|
|
|
|
debug> next
|
|
|
|
break in /home/indutny/Code/git/indutny/myscript.js:4
|
2016-01-24 10:15:51 +01:00
|
|
|
2 setTimeout(() => {
|
2016-01-17 18:39:07 +01:00
|
|
|
3 debugger;
|
|
|
|
4 console.log('world');
|
|
|
|
5 }, 1000);
|
|
|
|
6 console.log('hello');
|
|
|
|
debug> repl
|
|
|
|
Press Ctrl + C to leave debug repl
|
|
|
|
> x
|
|
|
|
5
|
|
|
|
> 2+2
|
|
|
|
4
|
|
|
|
debug> next
|
|
|
|
< world
|
|
|
|
break in /home/indutny/Code/git/indutny/myscript.js:5
|
|
|
|
3 debugger;
|
|
|
|
4 console.log('world');
|
|
|
|
5 }, 1000);
|
|
|
|
6 console.log('hello');
|
|
|
|
7
|
|
|
|
debug> quit
|
|
|
|
```
|
2010-12-31 03:46:49 +01:00
|
|
|
|
2015-12-27 06:19:35 +01:00
|
|
|
The `repl` command allows code to be evaluated remotely. The `next` command
|
2016-05-27 01:35:23 +02:00
|
|
|
steps to the next line. Type `help` to see what other commands are available.
|
2010-12-31 03:46:49 +01:00
|
|
|
|
2016-04-06 02:17:33 +02:00
|
|
|
Pressing `enter` without typing a command will repeat the previous debugger
|
|
|
|
command.
|
|
|
|
|
2012-02-27 20:08:17 +01:00
|
|
|
## Watchers
|
2011-10-01 09:28:57 +02:00
|
|
|
|
2015-12-27 06:19:35 +01:00
|
|
|
It is possible to watch expression and variable values while debugging. On
|
|
|
|
every breakpoint, each expression from the watchers list will be evaluated
|
|
|
|
in the current context and displayed immediately before the breakpoint's
|
|
|
|
source code listing.
|
2011-10-01 09:28:57 +02:00
|
|
|
|
2015-12-27 06:19:35 +01:00
|
|
|
To begin watching an expression, type `watch('my_expression')`. The command
|
|
|
|
`watchers` will print the active watchers. To remove a watcher, type
|
|
|
|
`unwatch('my_expression')`.
|
2011-10-01 09:28:57 +02:00
|
|
|
|
2016-05-27 01:35:23 +02:00
|
|
|
## Command reference
|
2011-10-01 09:28:57 +02:00
|
|
|
|
2012-02-27 20:08:17 +01:00
|
|
|
### Stepping
|
2011-10-01 09:28:57 +02:00
|
|
|
|
|
|
|
* `cont`, `c` - Continue execution
|
|
|
|
* `next`, `n` - Step next
|
|
|
|
* `step`, `s` - Step in
|
|
|
|
* `out`, `o` - Step out
|
2013-03-28 15:19:10 +01:00
|
|
|
* `pause` - Pause running code (like pause button in Developer Tools)
|
2011-10-01 09:28:57 +02:00
|
|
|
|
2012-02-27 20:08:17 +01:00
|
|
|
### Breakpoints
|
2011-10-01 09:28:57 +02:00
|
|
|
|
|
|
|
* `setBreakpoint()`, `sb()` - Set breakpoint on current line
|
2011-12-19 22:09:54 +01:00
|
|
|
* `setBreakpoint(line)`, `sb(line)` - Set breakpoint on specific line
|
2011-10-01 09:28:57 +02:00
|
|
|
* `setBreakpoint('fn()')`, `sb(...)` - Set breakpoint on a first statement in
|
|
|
|
functions body
|
|
|
|
* `setBreakpoint('script.js', 1)`, `sb(...)` - Set breakpoint on first line of
|
|
|
|
script.js
|
2014-12-16 17:27:31 +01:00
|
|
|
* `clearBreakpoint('script.js', 1)`, `cb(...)` - Clear breakpoint in script.js
|
|
|
|
on line 1
|
2011-10-01 09:28:57 +02:00
|
|
|
|
2013-04-26 08:05:33 +02:00
|
|
|
It is also possible to set a breakpoint in a file (module) that
|
|
|
|
isn't loaded yet:
|
|
|
|
|
2016-07-09 07:13:09 +02:00
|
|
|
```txt
|
2016-10-05 23:49:59 +02:00
|
|
|
$ node debug test/fixtures/break-in-module/main.js
|
2016-01-17 18:39:07 +01:00
|
|
|
< debugger listening on port 5858
|
|
|
|
connecting to port 5858... ok
|
|
|
|
break in test/fixtures/break-in-module/main.js:1
|
|
|
|
1 var mod = require('./mod.js');
|
|
|
|
2 mod.hello();
|
|
|
|
3 mod.hello();
|
|
|
|
debug> setBreakpoint('mod.js', 23)
|
|
|
|
Warning: script 'mod.js' was not loaded yet.
|
|
|
|
1 var mod = require('./mod.js');
|
|
|
|
2 mod.hello();
|
|
|
|
3 mod.hello();
|
|
|
|
debug> c
|
|
|
|
break in test/fixtures/break-in-module/mod.js:23
|
|
|
|
21
|
2016-01-24 10:15:51 +01:00
|
|
|
22 exports.hello = () => {
|
2016-01-17 18:39:07 +01:00
|
|
|
23 return 'hello from module';
|
|
|
|
24 };
|
|
|
|
25
|
|
|
|
debug>
|
|
|
|
```
|
2013-04-26 08:05:33 +02:00
|
|
|
|
2016-05-27 01:35:23 +02:00
|
|
|
### Information
|
2011-10-01 09:28:57 +02:00
|
|
|
|
|
|
|
* `backtrace`, `bt` - Print backtrace of current execution frame
|
|
|
|
* `list(5)` - List scripts source code with 5 line context (5 lines before and
|
|
|
|
after)
|
|
|
|
* `watch(expr)` - Add expression to watch list
|
|
|
|
* `unwatch(expr)` - Remove expression from watch list
|
|
|
|
* `watchers` - List all watchers and their values (automatically listed on each
|
|
|
|
breakpoint)
|
|
|
|
* `repl` - Open debugger's repl for evaluation in debugging script's context
|
2015-04-21 18:34:52 +02:00
|
|
|
* `exec expr` - Execute an expression in debugging script's context
|
2011-10-01 09:28:57 +02:00
|
|
|
|
2012-02-27 20:08:17 +01:00
|
|
|
### Execution control
|
2011-10-01 09:28:57 +02:00
|
|
|
|
|
|
|
* `run` - Run script (automatically runs on debugger's start)
|
|
|
|
* `restart` - Restart script
|
|
|
|
* `kill` - Kill script
|
|
|
|
|
2012-02-27 20:08:17 +01:00
|
|
|
### Various
|
2011-10-01 09:28:57 +02:00
|
|
|
|
|
|
|
* `scripts` - List all loaded scripts
|
2015-12-27 06:19:35 +01:00
|
|
|
* `version` - Display V8's version
|
2010-12-31 03:46:49 +01:00
|
|
|
|
2012-02-27 20:08:17 +01:00
|
|
|
## Advanced Usage
|
2010-12-31 03:46:49 +01:00
|
|
|
|
2015-12-27 06:19:35 +01:00
|
|
|
An alternative way of enabling and accessing the debugger is to start
|
|
|
|
Node.js with the `--debug` command-line flag or by signaling an existing
|
|
|
|
Node.js process with `SIGUSR1`.
|
2012-12-06 01:01:41 +01:00
|
|
|
|
2016-05-27 01:35:23 +02:00
|
|
|
Once a process has been set in debug mode this way, it can be inspected
|
2015-12-27 06:19:35 +01:00
|
|
|
using the Node.js debugger by either connecting to the `pid` of the running
|
|
|
|
process or via URI reference to the listening debugger:
|
2012-12-06 01:01:41 +01:00
|
|
|
|
2015-08-13 18:14:34 +02:00
|
|
|
* `node debug -p <pid>` - Connects to the process via the `pid`
|
2015-12-27 06:19:35 +01:00
|
|
|
* `node debug <URI>` - Connects to the process via the URI such as
|
|
|
|
localhost:5858
|
2015-11-14 04:21:49 +01:00
|
|
|
|
2016-02-07 17:47:14 +01:00
|
|
|
## V8 Inspector Integration for Node.js
|
|
|
|
|
2016-09-20 06:44:22 +02:00
|
|
|
**NOTE: This is an experimental feature.**
|
2016-02-07 17:47:14 +01:00
|
|
|
|
|
|
|
V8 Inspector integration allows attaching Chrome DevTools to Node.js
|
|
|
|
instances for debugging and profiling.
|
|
|
|
|
|
|
|
V8 Inspector can be enabled by passing the `--inspect` flag when starting a
|
|
|
|
Node.js application. It is also possible to supply a custom port with that flag,
|
|
|
|
e.g. `--inspect=9222` will accept DevTools connections on port 9222.
|
|
|
|
|
|
|
|
To break on the first line of the application code, provide the `--debug-brk`
|
|
|
|
flag in addition to `--inspect`.
|
|
|
|
|
2016-09-29 10:43:51 +02:00
|
|
|
```txt
|
|
|
|
$ node --inspect index.js
|
|
|
|
Debugger listening on port 9229.
|
|
|
|
Warning: This is an experimental feature and could change at any time.
|
|
|
|
To start debugging, open the following URL in Chrome:
|
|
|
|
chrome-devtools://devtools/remote/serve_file/@60cd6e859b9f557d2312f5bf532f6aec5f284980/inspector.html?experiments=true&v8only=true&ws=localhost:9229/node
|
|
|
|
```
|
|
|
|
|
2015-12-27 06:19:35 +01:00
|
|
|
[TCP-based protocol]: https://github.com/v8/v8/wiki/Debugging-Protocol
|