[英]create cron to restart pm2 instance fails
我在使用cron選項卡重新啟動實例時遇到麻煩
#!/usr/bin/node
*15 * * * * /usr/bin/node /usr/bin/pm2 restart 4
但是我的問題是我有兩個pm2守護程序。 我想要的那個在/opt.pm2中,所以每次我想使用pm2時,我都需要使用此命令
export PM2_HOME="/opt/.pm2"
而且我需要知道如何在crontab中傳遞此env變量以重新啟動實例4,原因是在/ usr / bin / pm2中我沒有運行我的應用程序?
但是我得到了錯誤
From root@ip120.ip-46-105-248.eu Sun Nov 12 11:23:01 2017
Return-Path: <root@ip120.ip-46-105-248.eu>
X-Original-To: root
Delivered-To: root@ip120.ip-46-105-248.eu
Received: by ip120.ip-46-105-248.eu (Postfix, from userid 0)
id E84CA100921; Sun, 12 Nov 2017 11:23:01 +0000 (WET)
From: "(Cron Daemon)" <root@ip120.ip-46-105-248.eu>
To: root@ip120.ip-46-105-248.eu
Subject: Cron <root@ip120> /usr/bin/node /usr/bin/pm2 restart 4
Content-Type: text/plain; charset=UTF-8
Auto-Submitted: auto-generated
Precedence: bulk
X-Cron-Env: <XDG_SESSION_ID=4300>
X-Cron-Env: <XDG_RUNTIME_DIR=/run/user/0>
X-Cron-Env: <LANG=en_US.UTF-8>
X-Cron-Env: <SHELL=/bin/sh>
X-Cron-Env: <HOME=/root>
X-Cron-Env: <PATH=/usr/bin:/bin>
X-Cron-Env: <LOGNAME=root>
X-Cron-Env: <USER=root>
Message-Id: <20171112112301.E84CA100921@ip120.ip-46-105-248.eu>
Date: Sun, 12 Nov 2017 11:23:01 +0000 (WET)
Use --update-env to update environment variables
[PM2] Applying action restartProcessId on app [4](ids: 4)
[PM2][ERROR] Process 4 not found
┌──────────┬────┬──────┬─────┬────────┬─────────┬────────┬─────┬─────┬──────────┐
│ App name │ id │ mode │ pid │ status │ restart │ uptime │ cpu │ mem │ watching │
└──────────┴────┴──────┴─────┴────────┴─────────┴────────┴─────┴─────┴──────────┘
Module activated
┌───────────────┬─────────┬────────────┬────────┬─────────┬─────┬─────────────┐
│ Module │ version │ target PID │ status │ restart │ cpu │ memory │
├───────────────┼─────────┼────────────┼────────┼─────────┼─────┼─────────────┤
│ pm2-logrotate │ 2.2.0 │ N/A │ online │ 0 │ 0% │ 91.223 MB │
└───────────────┴─────────┴────────────┴────────┴─────────┴─────┴─────────────┘
Use `pm2 show <id|name>` to get more details about an app
如果除環境變量外所有其他條件都相同,則可以將crontab命令設置為env PM2_HOME="/opt/.pm2" /usr/bin/node /usr/bin/pm2 restart 4
。 或/usr/bin/env
而不是env
。
如果您無法通過這種方式獲得成功,則可以編寫一個小的Shell腳本,該腳本僅導出PM2_HOME值並重新啟動pm2。 然后將這個shell腳本作為cron命令。
做@sapht告訴我的事情
crontab -l
#!/usr/bin/node
*/45 * * * * env PM2_HOME="/opt/.pm2" /usr/bin/node /usr/bin/pm2 restart 4
我得到這個輸出
From root@ip120.ip-46-105-248.eu Sun Nov 12 12:15:02 2017
Return-Path: <root@ip120.ip-46-105-248.eu>
X-Original-To: root
Delivered-To: root@ip120.ip-46-105-248.eu
Received: by ip120.ip-46-105-248.eu (Postfix, from userid 0)
id 7FC6010092C; Sun, 12 Nov 2017 12:15:02 +0000 (WET)
From: "(Cron Daemon)" <root@ip120.ip-46-105-248.eu>
To: root@ip120.ip-46-105-248.eu
Subject: Cron <root@ip120> env PM2_HOME="/opt/.pm2" /usr/bin/node /usr/bin/pm2 restart 4
Content-Type: text/plain; charset=UTF-8
Auto-Submitted: auto-generated
Precedence: bulk
X-Cron-Env: <XDG_SESSION_ID=4304>
X-Cron-Env: <XDG_RUNTIME_DIR=/run/user/0>
X-Cron-Env: <LANG=en_US.UTF-8>
X-Cron-Env: <SHELL=/bin/sh>
X-Cron-Env: <HOME=/root>
X-Cron-Env: <PATH=/usr/bin:/bin>
X-Cron-Env: <LOGNAME=root>
X-Cron-Env: <USER=root>
Message-Id: <20171112121502.7FC6010092C@ip120.ip-46-105-248.eu>
Date: Sun, 12 Nov 2017 12:15:02 +0000 (WET)
Use --update-env to update environment variables
[PM2] Applying action restartProcessId on app [4](ids: 4)
[PM2] [wscontroller-gps-service](4) ✓
┌──────────────────────────┬────┬─────────┬───────┬────────┬─────────┬────────┬─────┬───────────┬──────────┐
│ App name │ id │ mode │ pid │ status │ restart │ uptime │ cpu │ mem │ watching │
├──────────────────────────┼────┼─────────┼───────┼────────┼─────────┼────────┼─────┼───────────┼──────────┤
│ wscontroller-api │ 2 │ cluster │ 25521 │ online │ 0 │ 47m │ 0% │ 47.6 MB │ disabled │
│ wscontroller-gps-service │ 4 │ fork │ 2974 │ online │ 5 │ 0s │ 99% │ 14.0 MB │ disabled │
│ wscontroller-proxy │ 5 │ cluster │ 25549 │ online │ 0 │ 47m │ 0% │ 45.5 MB │ disabled │
│ wscontroller-service │ 3 │ cluster │ 29681 │ online │ 1 │ 28m │ 31% │ 83.6 MB │ disabled │
│ wscontroller-ui-server │ 1 │ cluster │ 25515 │ online │ 0 │ 47m │ 0% │ 35.7 MB │ disabled │
└──────────────────────────┴────┴─────────┴───────┴────────┴─────────┴────────┴─────┴───────────┴──────────┘
Module activated
┌───────────────┬─────────┬────────────┬────────┬─────────┬─────┬─────────────┐
│ Module │ version │ target PID │ status │ restart │ cpu │ memory │
├───────────────┼─────────┼────────────┼────────┼─────────┼─────┼─────────────┤
│ pm2-logrotate │ 2.2.0 │ N/A │ online │ 0 │ 0% │ 36.527 MB │
└───────────────┴─────────┴────────────┴────────┴─────────┴─────┴─────────────┘
Use `pm2 show <id|name>` to get more details about an app
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.