Nodejs进程在服务器重新启动时未收到SIGTERM

问题描述

我有一个简单的以下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.jsforever --killSignal SIGTERM start /data/script.js的身份运行脚本时,它在重新启动时不起作用-未写入文件。因此,对于非root用户,它不能直接通过node命令运行,也不能通过forever命令运行。我总是需要以非root用户身份运行nodejs进程。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...