node.js的进程保活

nodejs的进程保活其实用PM2应该更好用些,不过由于原理其实并不复杂,我们可以自己手写一个服务来干这个工作。

假设我们有一个服务,可以这样来定义下它的相关信息:

javascript 复制代码
const svcs=[
{"sid":"apl","name":"application.js"},
...
]

我们是这样启动这个服务的:

bash 复制代码
node application.js

服务启动时将进程id保存到这个pid文件中

javascript 复制代码
const { pid } = require('node:process');
...
fs.writeFileSync("pid/s"+sid+".pid"," "+pid);

这样,我们可以根据svcs的定义定时检查pids目录下的这些文件,看它们的进程还在不?不在的话,执行启动服务命令拉起服务。

javascript 复制代码
//keepalive.js
const fs=require("fs");
const { spawn } = require('child_process');
const gitBashPath = 'C:\\Program Files\\Git\\bin\\bash.exe';
const svcPath='/c/nodeproj/'

function pidIsRunning(svcpid) {
	try {
		process.kill(svcpid, 0); return true;
	} catch (e) { return false; }
}

const svcs=[
	{ "id":"apl","name":"application.js" }
	];

svcs.forEach(svc=>{
	let svcpid = fs.readFileSync("pid/"+svc["id"]+".pid","utf8").substr(1);
	console.log(svc);
	console.log(svcpid);
	let svcalive=pidIsRunning(svcpid);
	console.log(svcalive);

	if (!svcalive) {
		const child = spawn(gitBashPath, ['-c', 'node '+svcPath+svc["name"]+' &'],{ detached: true, stdio: 'ignore' });
		child.unref();
		}
	});
process.exit(0);

注意spawn带上{ detached: true, stdio: 'ignore' }参数,是为了确保主进程退出,后台服务仍然保持运行。

上面这个例程是一个一次性运行的脚本,可以简单的改造成定时任务,就从略了。

相关推荐
码事漫谈15 分钟前
VS Code Copilot 内联聊天与提示词技巧指南
后端
Moonbit23 分钟前
MoonBit Perals Vol.06: MoonBit 与 LLVM 共舞 (上):编译前端实现
后端·算法·编程语言
Moonbit24 分钟前
MoonBit Perals Vol.06: MoonBit 与 LLVM 共舞(下):llvm IR 代码生成
后端·程序员·代码规范
Moonbit32 分钟前
MoonBit Pearls Vol.05: 函数式里的依赖注入:Reader Monad
后端·rust·编程语言
bobz9651 小时前
ThanosRuler
后端
用户4822137167751 小时前
C++——字符串常量、二维数组、函数与指针的深度应用(补)
后端
用户4822137167751 小时前
C++——类型转换
后端
lichenyang4531 小时前
mongoose(对象文档模型库)的使用
后端
用户4822137167751 小时前
C++——继承进阶
后端
洛卡卡了2 小时前
数据库加密方案实践:我们选的不是最完美,但是真的够用了。
数据库·后端·面试