Skip to content

eggjs/cluster

Repository files navigation

egg-cluster

NPM versionCITest coverageKnown Vulnerabilitiesnpm download

Cluster Manager for EggJS


Install

npm i egg-cluster --save

Usage

conststartCluster=require('egg-cluster').startCluster;startCluster({baseDir: '/path/to/app',framework: '/path/to/framework',});

You can specify a callback that will be invoked when application has started. However, master process will exit when catch an error.

startCluster(options,()=>{console.log('started');});

Options

ParamTypeDescription
baseDirStringdirectory of application
frameworkStringspecify framework that can be absolute path or npm package
pluginsObjectplugins for unittest
workersNumbernumbers of app workers
stickyBooleansticky mode server
portNumberport
reusePortBoolean(Required Node.js >= 22.12.0) allows multiple sockets on the same host to bind to the same port. Incoming connections are distributed by the operating system to listening sockets. This option is available only on some platforms, such as Linux 3.9+, DragonFlyBSD 3.6+, FreeBSD 12.0+, Solaris 11.4, and AIX 7.2.5+. Default:false
debugPortNumberthe debug port only listen on http protocol
httpsObjectstart a https server, note: key / cert / ca should be full path to file
requireArray|Stringwill inject into worker/agent process
pidFileStringwill save master pid to this file
startModeStringdefault is 'process', use 'worker_threads' to start the app & agent worker by worker_threads
portsArraystartup port of each app worker, such as: [7001, 7002, 7003], only effects when the startMode is 'worker_threads' and reusePort is false
envStringcustom env, default is process.env.EGG_SERVER_ENV

Env

EGG_APP_CLOSE_TIMEOUT: app worker boot timeout value

EGG_AGENT_CLOSE_TIMEOUT: agent worker boot timeout value

License

MIT

Contributors

Contributors

Made with contributors-img.

About

cluster manager for egg

Topics

Resources

License

Stars

Watchers

Forks

Contributors 22