node+cross-spawn运行批处理脚本
run.js:
const spawn = require('cross-spawn');
spawn.sync('yarn -v', [], { stdio: 'inherit' })
spawn.sync('run.bat origin/master', [], { stdio: 'inherit' })
run.bat:
echo %0 %1
cd /temp/m-node-edu/%1
call yarn -v
call yarn
@REM name会自动应用到pm2配置文件ecosystem.config.js的name字段
set name=%1
call pm2 start ecosystem.config.js --env production && pm2 logs
ecosystem.config.js:
module.exports = {
apps: [
{
script: './app.js',
watch: true,
ignore_watch: ['node_modules', 'log', 'dbFile', '.git'],
node_args: ['--inspect'],
env_development: {
PORT: 81,
NODE_ENV: 'development'
},
env_production: {
PORT: 81,
NODE_ENV: 'production'
}
}
]
}
在windows系统上使用加上shell选项 。虽然在 Linux, macOS 等系统上不需要设置 shell
选项,命令也能够正常执行;设置 shell
为 true
也不会妨碍命令的执行,只是会额外的产生一个本不必要的 shell 进程,影响性能。
const spawn = require('cross-spawn')
spawn.sync('yarn -v', [], { stdio: 'inherit' })
//spawn.sync('run.bat origin/master', [], { stdio: 'inherit' })
spawn.sync('echo const prettylist = > prettylist.js', [], {
stdio: 'inherit',
shell: true
})
spawn.sync('pm2 prettylist >> prettylist.js', [], { stdio: 'inherit' })
//result = Array.from(result).map(item => item.pid)
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步