Skip to content
Corey Butler edited this page Apr 24, 2017 · 13 revisions

Frequently Asked Questions

My script installs but won't start (with no error).

Sometimes this logs "The process terminated unexpectedly.". Often times the script runs perfectly when used without using node-windows, but fails to start when node-windows is used. The most common cause for this is a faulty installation.

var svc = new Service({
name:'MyService',
description: 'Description',
script: __dirname + "index.js" // <--- PROBLEM IS HERE
});

The problem above is the use of the __dirname variable, which is a a relative reference (as opposed to an absolute reference). Since node-windows uses a wrapper, __dirname refers to the root of the node-windows module, not your script. Per the instructions on the README, always use an absolute path.

Why doesn't this work on Windows XP?

Node-windows is not supported on operating systems that have reached EOL (End of Life) with Microsoft.

Why doesn't this work with supervisor, forever, or nssm?

Supervisor, Forever, and NSSM all provide the same functionality as node-windows. Using them together would be like using a hammer to use a hammer to pound a nail, i.e. it's redundant. Use node-windows OR one of these others.

Node-windows used to be based on NSSM, but it was more limited than winsw.exe (which node-windows is currently based on). Supervisor and Forever are both great modules, but they're a little different from node-windows. Node-windows uses the operating systems' native uptime functionality instead of recreating it within node. This allows it to interact with existing system monitors (Nagios, System Center Essentials, etc).

Where does my console.log output go?

They get logged to stdout, which means they won't show up in the event log. Normally, this is just dumped to the console, but since node-windows processes aren't running in a console, these messages are essentially lost without some other means of capturing them. As of right now, it's best to use the built in logging capabilities of node-windows or another dedicated logging module to write application info to a file.

That said, I have considered adding a configuration attribute to allow for redirecting console.log to the event log.... but the event log isn't really supposed to be a full syslog... so I'm on the fence between principle and pragmatism.

My script runs fine on it's own, but not with node-windows. Why?

The most common reason for this type of behavior is the configuration of a path. For example, a lot of people use __dirname to define a path within their script without understanding __dirname is a relative path. It can and often does differ between a child and parent process. As the documentation suggests, it is always best to use absolute paths, not relative paths. Remember that node-windows spawns your script as a new child process, which is why the working directory is different from when you run node myscript.js. This is not specific to node-windows, this is the context most Windows background services run in.

Another common issue is a misunderstanding of how a third party module is used within an app. Some modules make assumptions about the context in which they're running. Make sure you understand what your third party modules are doing, don't just use them blindly. Running a node script as a daemon is very different from running as a server or worker.

Can a .exe created with node-windows run on a computer without Node.js installed?

Short answer: No.

Detailed answer: node-windows is designed to run on systems with Node.js installed. It is a wrapper for managing the not-so-intuitive parts of dealing with background services and logging on Windows (or Mac/Linux). The purpose of this project is not to create fully bound binaries. Node.js is updated frequently, often times with vulnerability patches. By maintaining separation, it is possible to apply new versions of Node.js to a computer without modifying the generated node-windows executable.

For version management, please see NVM for Windows.

If you really want to ship a completely self-contained Node-based application, Electron and NW.js are good options. I haven't used it, but nexe looks promising if you just want to ship a single executable.

Clone this wiki locally