supervisord如何成功重启npm start命令?

时间:2017-10-17 22:30:14

标签: node.js supervisord

我已经启动了"节点启动"通过supervisord。

我的问题是 在supervisord上停止/重新启动将导致节点app.js进程保持不被杀死

在这种情况下,supervisord如何成功重启npm start命令?

supervisord.conf

[supervisord]
nodaemon=true

[program:node]
command=npm start 
directory=/xx
stdout_logfile=/dev/stdout
stdout_logfile_maxbytes=0
stderr_logfile=/dev/stderr
stderr_logfile_maxbytes=0
user=root
autostart=true
autorestart=true
redirect_stderr=true
exitcodes=1

的package.json

{
  "name": "xx",
  "version": "1.0.0",
  "main": "app.js",
  "scripts": {
    "start": "node app.js"
  },
  "author": "",
  "license": "ISC",
  "dependencies": {
    "xxx
  },
  "devDependencies": {
    "nodemon": "^1.11.0"
  },
  "description": ""
}

1 个答案:

答案 0 :(得分:2)

这对我有用:将Supervisor配置文件中的npm start更改为node app.js

为什么?

我注意到使用npm start启动了两个过程:

$ ps aux | grep node
ubuntu   19363  0.0  0.0   4508   708 ?        S    17:43   0:00 sh -c node index.js
ubuntu   19364  1.3  5.2 1041288 52996 ?       Sl   17:43   0:00 node index.js

在Supervisor中停止它只会停止父进程:

$ sudo supervisorctl stop all
my_worker: stopped
$ ps aux | grep node
ubuntu   19364  0.3  5.2 1041288 52996 ?       Sl   17:43   0:00 node index.js

因此,将node index.js直接放在超级用户配置中为我解决了这个问题。