Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/fredguile/cluster-respawn
My own cluster manager for node.js applications
https://github.com/fredguile/cluster-respawn
archived deprecated nodejs obsolete
Last synced: about 1 month ago
JSON representation
My own cluster manager for node.js applications
- Host: GitHub
- URL: https://github.com/fredguile/cluster-respawn
- Owner: fredguile
- License: mit
- Created: 2015-12-28T14:54:23.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2021-04-13T03:06:38.000Z (almost 4 years ago)
- Last Synced: 2024-11-22T18:17:53.369Z (about 2 months ago)
- Topics: archived, deprecated, nodejs, obsolete
- Language: JavaScript
- Homepage:
- Size: 15.6 KB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# **DEPRECATED** - cluster-respawn
**[this project is no longer actively maintained]**
My own cluster manager for node.js applications.
**DISCLAIMER: This was my "introductory project" for learning Node.js. I wouldn't use it today as `cluster-respawn` doesn't comply with the [twelve-factor app manifesto](https://12factor.net/) and that I'm mostly hosting Node.js app on PaaS/IaaS.**
Despite there are already some cluster management modules on npmjs.com, I found it was a good exercice to write my own lib where I could put some handy features like:
- my typical Makefile: it may look old school, but I get shorter commands to type and I can easily set up default environment variables for my preferred platforms (OSX and Windows). You can use make on Windows after installing the [right tools](http://scoop.sh/).
- workers reloading: I use this quite often during development. Just type "make reload" (it sends a signal to the master process to respawn all workers). You can easily set up a shortcut for that in your IDE, and you can programmatically bind the module API to any watcher for reloading on file change.
- master process events: to hook anything when the cluster is reloading or shutting down.
- workers messages: using the native feature of Node's processes.
## Installation and Usage
#### First steps
Type "make" to get an overview of the available commands. If you're checking the project, run "make build".
Or just run "make example" to try out the example snippet located in "src/example". You should get some debug statements describing the cluster activity. Try hitting CTRL-C or typing "make reload".
#### Usage
```js
import clusterRespawnApi from 'cluster-respawn';
```Gives you a "per-process" singleton.
```js
clusterRespawnApi::init(options)
```First off, you must call this from your master script, passing the [default Node's cluster options](https://nodejs.org/api/cluster.html#cluster_cluster_settings), and some additional ones:
- childProcesses: the amount of workers you want to (re-)spawn
- root: the root folder where Node is running (defaults to process.cwd())
- writePidFiles: true if you want to have PID files generated in the root folder (enable this to use "make reload")
- enableReload: true if you want to reload all workers when a SIGUSR2 is received by the master process (enable this to use "make reload")
- masterShutdownTimeout: the timeout in ms after which the master process is killed
- workerShutdownTimeout: the timeout in ms after which a shutting down worker is killed
- onMessage: a callback handling workers message, [see Node documentation](https://nodejs.org/api/cluster.html#cluster_event_message)```js
clusterRespawnApi::boot()
```Call this at last to boot your cluster. You can chain it to init().
```js
clusterRespawnApi::respawn(count)
```Call this to respawn all workers. You can specify the amout of workers you want to respawn.
```js
clusterRespawnApi::shutdown()
```Call this to shutdown the cluster.
#### Tests
Run "make test".
#### Concrete example
Still too abstract? Then I recommend to check out my [React starter kit](https://www.npmjs.com/package/react-redux-es2015-starter-kit) which is using cluster-respawn. After all, the module was initiated for this purpose.