问题描述
我有一个简单的以下nodejs脚本,该脚本以root身份在Debian VPS服务器上运行(命令node /data/script.js
)...
var fs = require('fs');
var counter = 0;
setInterval(function() {
counter++;
console.log(counter);
},1000);
function handle(signal) {
fs.writeFileSync("/data/temp-handle.txt","" + counter + "; " + signal,"utf8");
console.log(signal);
process.exit();
}
process.on('SIGTERM',handle);
1。)当我从另一个终端运行reboot
命令时,服务器关闭并向上启动,但没有任何内容写入/data/temp-handle.txt,并且文件不存在(目录存在且可写)。当我只是使用SIGTERM测试杀死进程时,它是正确编写的。重新启动可能在哪里出现问题?
2。)当我在重启后通过命令forever --killSignal SIGTERM start /data/script.js
运行脚本时,写入了/data/temp-handle.txt命令文件。因此问题1)可以通过使用forever
(无论如何我都使用)来解决。但是直接node
命令有什么问题?
3。)当我以另一个用户su - myuser
的身份运行脚本,然后以node /data/script.js
或forever --killSignal SIGTERM start /data/script.js
的身份运行脚本时,它在重新启动时不起作用-未写入文件。因此,对于非root用户,它不能直接通过node
命令运行,也不能通过forever
命令运行。我总是需要以非root用户身份运行nodejs进程。
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)