Skip to content

xuezier/egg-cluster-script

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

42 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

******************************************************************
******************************************************************
**********              代码千万行,注释第一行              **********
**********              编码不规范,同事泪两行              **********
******************************************************************
******************************************************************

eggjs 部署脚本

仿造 egg-script 的集群热部署方案,支持单机集群的热部署平滑重启更新

支持 egg-script 启动日志

installation

npm install egg-cluster-script --save-dev

usage

npx egg-cluster-bin <command> [...options]

Command

command description
start 启动服务
stop 终止服务
reload 重启集群,平滑模式
startOrReload 启动/重启服务,自动根据 title 判断

Options

参数在作用于服务启动的时候

option description value type
'-i, --instances <n>' worker 进程数, default 1 Number
'-p, --port <p>' egg 应用启动监听端口 Number
'-t, --title <t>' egg 应用�名称 String
'-d, --daemon' 守护进程模式,添加此参数后,服务启动后会进入后台守护进程模式 不需要参数值
'-l, --logDir <d>' 日志保存目录 String
'-b, --baseDir <d>' 项目启动目录 String
'--ignore-stderr' 忽略错误信息启动 不需要参数值

title 参数使用在所有的命令中

closehook

在 worker 重启的过程中,应该及时切走流量,让正在重启的 worker 不再接收新的请求,并在超时时间内处理好已经连接的请求,

如果正在连接的请求超过了超时时间,那么 worker 就已经被关闭了,这些请求会返回错误

//app.js

module.exports = app => {

    app.beforeClose(async() => {
        const server = app.server;
        // 在worker重启的时候,禁止新的请求访问
        server.close();
        // 访问请求超时
        await new Promise(resolve => setTimeout(resolve, 5000));
    });

}

app-worker 在接收到关闭命令的时候,会触发这个钩子,终止新的请求,并在 5s 后被关闭,如果 5s 内已请求的连接没有完成,会被释放

todo

  • ✅ 添加command: startOrReload 自动判断是否需要�启动或重启
  • �支持所有egg-script参数
  • 🔥 添加更多参数
  • 🔥 优化ipc
  • 想要什么,提issue吧

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published