processhost
v1.0.0
Published
a ridiculously simple process host
Downloads
14
Keywords
Readme
processhost
Simple, cross-platform, process hosting for Node, adapted from [Anvil]'s(https://github.com/anviljs/anvil.js) processhost.
The most useful features are:
- Reliably kills child processes on host process exit
- Reliably restarts crashed child processes
- Apply limits to restart behavior
API
var processes = require( "processhost" )();
configuration
Configuration hash has the following options. Only command and args are required.
{
command: "", // this will probably be "node"
args: [], // the command line args for the process, i.e. your script
[cwd]: "", // defaults to current working directory
[killSignal]: "" | [ "" ], // not required, defaults to "SIGTERM", can provide an array
[stdio]: "inherit" | "ignore" | "pipe" // determines if the process will write to the console
[env]: {}, // defaults to the process.env, should be simple hash
[restart]: true, // control whether or not the process restarts after a start or restart call
[restartLimit]: 1, // number of allowed restarts
[restartWindow]: 100 // duration (in ms) of tolerance window
}
Notes
restartWindow
defaults to undefined - this results in limitless restarts
stdio
defaults to "inherit" causing child processes to share the parents stdout/stderr
create( processAlias, configuration )
Creates a new process without starting it.
processes.create( "myProcess", { command: "node", args: [ "./index.js" ], cwd: "./src" } );
restart( [processAlias] )
If a processAlias
is provided, only starts|restarts the matching process. Otherwise, this will start|restart ALL processes that have been defined.
processes.restart(); // restart all
processes.restart( 'myApp' ); // restart only 'myApp'
setup( processesHash )
Used to define and potentially start multiple processes in a single call.
processes.setup( {
"one": { ... },
"two": { ... },
"three": { ... }
} );
Note
To have the processes started automatically, add a
start
: true to the config block.
start( processAlias, [configuration] )
If no configuration is provided, this will start|restart the matching process. If a configuration is provided, this will create and start a new process.
processes.start( "myProcess", { command: "node", args: [ "./index.js" ], cwd: "./src" } );
stop( [processAlias] )
If no processAlias
is provided, stops all running processes, otherwise it stops the specified process if it exists and is running.
processes.stop();
Events
You can subscribe to the following process level events off the process host.
- [processAlias].crashed - the process has exited unexpectedly
- [processAlias].failed - the process has exceeded the set tolerance
- [processAlias].restarting - the process is restarting
- [processAlias].started - the process has started
- [processAlias].stderr
- [processAlias].stdout
- [processAlias].stopped - the process has exited after
stop
was called
Note
The
stderr
andstdout
events cannot fire unless you setstdio
to "pipe" in the config hash.