{"id":31828,"date":"2023-12-13T14:38:28","date_gmt":"2023-02-24T13:48:35","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8pm2%e6%9d%a5%e8%bf%90%e8%a1%8cnode-js%e5%ba%94%e7%94%a8\/"},"modified":"2024-05-04T13:24:05","modified_gmt":"2024-05-04T05:24:05","slug":"%e4%bd%bf%e7%94%a8pm2%e6%9d%a5%e8%bf%90%e8%a1%8cnode-js%e5%ba%94%e7%94%a8","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8pm2%e6%9d%a5%e8%bf%90%e8%a1%8cnode-js%e5%ba%94%e7%94%a8\/","title":{"rendered":"\u4f7f\u7528PM2\u6765\u8fd0\u884cNode.js\u5e94\u7528"},"content":{"rendered":"<p>\u56e0\u70ba\u807d\u8aaapm2\u7684\u529f\u80fd\u6bd4forever\u66f4\u5f37\u5927\uff0c\u6240\u4ee5\u6211\u6c7a\u5b9a\u8a66\u8a66\u7528pm2\uff0c\u96d6\u7136\u6211\u4ee5\u524d\u6709\u7528\u904eforever\u3002<\/p>\n<h1>\u5b89\u88c5PM2<\/h1>\n<p>\u5168\u7403\u5b89\u88c5<\/p>\n<pre class=\"post-pre\"><code>npm i -g pm2\r\n<\/code><\/pre>\n<p>\u5982\u679c\u60a8\u7684\u7cfb\u7edf\u53ef\u4ee5\u8bc6\u522bpm2\u547d\u4ee4\uff0c\u5219\u5b89\u88c5\u5b8c\u6210\u3002<\/p>\n<h1>\u4f7f\u7528PM2\u542f\u52a8\u5e94\u7528\u7a0b\u5e8f\u3002<\/h1>\n<p>\u5982\u679c\u53ea\u662f\u7b80\u5355\u5730\u542f\u52a8js\u7a0b\u5e8f\uff0c\u53ef\u4ee5\u4f7f\u7528pm2 start\u3002<\/p>\n<pre class=\"post-pre\"><code>pm2 start js\u30d5\u30a1\u30a4\u30eb\r\n<\/code><\/pre>\n<p>\u53ef\u4ee5\u6307\u5b9a\u4e00\u4e2ajs\u6587\u4ef6\uff0c\u4f46\u4f7f\u7528&#8211;name\u9009\u9879\u4ee5\u547d\u540d\u542f\u52a8\u811a\u672c\u66f4\u65b9\u4fbf\u3002<\/p>\n<p>\u6211\u89c9\u5f97\u6ca1\u6709\u540d\u5b57\u64cd\u4f5c\u592a\u4e0d\u65b9\u4fbf\uff0c\u6240\u4ee5\u540d\u5b57\u662f\u5fc5\u9700\u7684\u3002<br \/>\n\u5982\u679c\u6587\u4ef6\u540d\u4e3a main.js\uff0c\u5728\u4f7f\u7528 pm2 list \u547d\u4ee4\u663e\u793a\u5e94\u7528\u7a0b\u5e8f\u5217\u8868\u65f6\uff0c\u4f1a\u663e\u793a main.js\uff0c\u7136\u540e\u5c31\u4f1a\u60f3\u201c\u8fd9\u662f\u54ea\u4e2a\u5e94\u7528\u7a0b\u5e8f\u6765\u7740\uff1f\u201d\u3002<\/p>\n<p>\u9019\u6b21\u4f5c\u70ba\u4e00\u500b\u7bc4\u4f8b\uff0c\u6211\u5011\u6703\u7528 &#8220;slack-bot&#8221; \u9019\u500b\u61c9\u7528\u7a0b\u5f0f\u540d\u7a31\u4f86\u555f\u52d5 pm2\u3002<\/p>\n<pre class=\"post-pre\"><code>$ pm2 start main.js --name slack-bot\r\n\r\n[PM2] Starting \/home\/pi\/dev\/slack-bot\/main.js in fork_mode (1 instance)\r\n[PM2] Done.\r\n\u250c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\r\n\u2502 App name  \u2502 id \u2502 mode \u2502 pid  \u2502 status \u2502 restart \u2502 uptime \u2502 cpu \u2502 mem       \u2502 user \u2502 watching \u2502\r\n\u251c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\r\n\u2502 slack-bot \u2502 0  \u2502 fork \u2502 1432 \u2502 online \u2502 0       \u2502 0s     \u2502 12% \u2502 20.0 MB   \u2502 pi   \u2502 disabled \u2502\r\n\u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518\r\n<\/code><\/pre>\n<p>\u7531\u4e8e\u72b6\u6001\u5df2\u7ecf\u5728\u7ebf\uff0c\u6240\u4ee5\u5df2\u7ecf\u542f\u52a8\u3002<\/p>\n<h1>\u91cd\u65b0\u542f\u52a8<\/h1>\n<p>\u4e0b\u53482\u70b9\u91cd\u542f\u5e94\u7528\u540d\u79f0<\/p>\n<pre class=\"post-pre\"><code>$ pm2 restart slack-bot\r\nUse --update-env to update environment variables\r\n[PM2] Applying action restartProcessId on app [slack-bot](ids: 0)\r\n[PM2] [slack-bot](0) \u2713\r\n\u250c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\r\n\u2502 App name  \u2502 id \u2502 mode \u2502 pid  \u2502 status \u2502 restart \u2502 uptime \u2502 cpu \u2502 mem       \u2502 user \u2502 watching \u2502\r\n\u251c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\r\n\u2502 slack-bot \u2502 0  \u2502 fork \u2502 1480 \u2502 online \u2502 1       \u2502 0s     \u2502 66% \u2502 15.1 MB   \u2502 pi   \u2502 disabled \u2502\r\n\u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518\r\n Use `pm2 show &lt;id|name&gt;` to get more details about an app\r\n<\/code><\/pre>\n<p>\u56e0\u4e3aPID\u6539\u53d8\u4e86\uff0c\u6240\u4ee5\u4f3c\u4e4e\u91cd\u65b0\u542f\u52a8\u4e86\u3002<\/p>\n<h1>\u7d42\u6b62<\/h1>\n<p>\u8bf7\u505c\u6b62\u5e94\u7528\u7a0b\u5e8f\uff1apm2 stop \u30a2\u30d7\u30ea\u540d<\/p>\n<pre class=\"post-pre\"><code>$ pm2 stop slack-bot\r\n[PM2] Applying action stopProcessId on app [slack-bot](ids: 0)\r\n[PM2] [slack-bot](0) \u2713\r\n\u250c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\r\n\u2502 App name  \u2502 id \u2502 mode \u2502 pid \u2502 status  \u2502 restart \u2502 uptime \u2502 cpu \u2502 mem    \u2502 user \u2502 watching \u2502\r\n\u251c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u253c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2524\r\n\u2502 slack-bot \u2502 0  \u2502 fork \u2502 0   \u2502 stopped \u2502 1       \u2502 0      \u2502 0%  \u2502 0 B    \u2502 pi   \u2502 disabled \u2502\r\n\u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518\r\n Use `pm2 show &lt;id|name&gt;` to get more details about an app\r\n<\/code><\/pre>\n<p>\u7531\u4e8e\u72b6\u6001\u663e\u793a\u4e3a\u505c\u6b62\uff0c\u770b\u8d77\u6765\u5df2\u7ecf\u505c\u6b62\u4e86\u3002<\/p>\n<h1>\u67e5\u770b\u65e5\u5fd7<\/h1>\n<p>\u4e0b\u53482\u70b9\u4e4b\u540e\uff0c\u6253\u5f00\u5e94\u7528\u7a0b\u5e8f\u65e5\u5fd7\u3002<\/p>\n<pre class=\"post-pre\"><code> $ pm2 logs slack-bot\r\n[TAILING] Tailing last 15 lines for [slack-bot] process (change the value with --lines option)\r\n\/home\/pi\/.pm2\/logs\/slack-bot-error-0.log last 15 lines:\r\n...\r\n<\/code><\/pre>\n<p>\u9ed8\u8ba4\u8bbe\u7f6e\u53ea\u80fd\u663e\u793a15\u884c\uff0c\u5982\u679c\u589e\u52a0\u663e\u793a\u884c\u6570\u4f1a\u66f4\u5bb9\u6613\u9605\u8bfb\u3002<\/p>\n<pre class=\"post-pre\"><code>pm2 logs slack-bot --lines 50\r\n<\/code><\/pre>\n<h1>\u6e05\u9664\u65e5\u5fd7<\/h1>\n<p>pm2 \u6e05\u7a7a\u7f13\u5b58<\/p>\n<h1>\u67e5\u770b\u5e94\u7528\u7a0b\u5e8f\u72b6\u6001<\/h1>\n<p>\u5c55\u793a pm2 \u4e2d\u7684\u5e94\u7528\u540d\u79f0<\/p>\n<p>\u53ef\u4ee5\u67e5\u770b\u5e94\u7528\u7a0b\u5e8f\u7684\u72b6\u6001\/\u8def\u5f84\/\u7248\u672c\u3002<\/p>\n<pre class=\"post-pre\"><code>\u250c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\r\n\u2502 status            \u2502 online                                                      \u2502\r\n\u2502 name              \u2502 slack-bot                                             \u2502\r\n\u2502 restarts          \u2502 2                                                           \u2502\r\n\u2502 uptime            \u2502 3h                                                          \u2502\r\n\u2502 script path       \u2502 \/home\/pi\/dev\/slack-bot\/receptionist.js                \u2502\r\n\u2502 script args       \u2502 token=xoxb-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx                  \u2502\r\n\u2502 error log path    \u2502 \/home\/pi\/.pm2\/logs\/slack-bot-error-0.log              \u2502\r\n\u2502 out log path      \u2502 \/home\/pi\/.pm2\/logs\/slack-bot-out-0.log                \u2502\r\n\u2502 pid path          \u2502 \/home\/pi\/.pm2\/pids\/slack-bot-0.pid                    \u2502\r\n\u2502 interpreter       \u2502 node                                                        \u2502\r\n\u2502 interpreter args  \u2502 N\/A                                                         \u2502\r\n\u2502 script id         \u2502 0                                                           \u2502\r\n\u2502 exec cwd          \u2502 \/home\/pi\/dev\/slack-bot                                \u2502\r\n\u2502 exec mode         \u2502 fork_mode                                                   \u2502\r\n\u2502 node.js version   \u2502 10.4.1                                                      \u2502\r\n\u2502 watch &amp; reload    \u2502 \u2714                                                           \u2502\r\n\u2502 unstable restarts \u2502 0                                                           \u2502\r\n\u2502 created at        \u2502 2018-11-19T02:17:46.158Z                                    \u2502\r\n\u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518\r\n Code metrics value\r\n\u250c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\r\n\u2502 Loop delay      \u2502 1.49ms \u2502\r\n\u2502 Active requests \u2502 0      \u2502\r\n\u2502 Active handles  \u2502 5      \u2502\r\n\u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518\r\n<\/code><\/pre>\n<h1>\u76d1\u63a7\u5e94\u7528\u7a0b\u5e8f<\/h1>\n<p>\u53ef\u4ee5\u67e5\u770b\u6b63\u5728\u8fd0\u884c\u7684\u5e94\u7528\u7684CPU\u4f7f\u7528\u7387\u3001\u5185\u5b58\u4f7f\u7528\u91cf\u3001\u5faa\u73af\u5ef6\u8fdf\u548c\u8bf7\u6c42\/\u5206\u949f\u3002<\/p>\n<pre class=\"post-pre\"><code>pm2 monit\r\n<\/code><\/pre>\n<p>\u6613\u4e8e\u9605\u8bfb\uff0c\u7a0d\u5fae\u6709\u70b9\u9177<\/p>\n<div><img decoding=\"async\" class=\"post-images\" title=\"\u30b9\u30af\u30ea\u30fc\u30f3\u30b7\u30e7\u30c3\u30c8 2018-04-27 18.41.53.png\" src=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d0ebf37434c4406bed687\/36-0.png\" alt=\"\u30b9\u30af\u30ea\u30fc\u30f3\u30b7\u30e7\u30c3\u30c8 2018-04-27 18.41.53.png\" \/><\/div>\n<p>\u6709\u4e00\u9879\u540d\u4e3aPM2 Plus\u7684\u670d\u52a1\uff0c\u4f3c\u4e4e\u53ef\u4ee5\u901a\u8fc7Web\u67e5\u770b\u7c7b\u4f3c\u4eea\u8868\u76d8\u7684\u4fe1\u606f\u3002\uff08\u8be6\u7ec6\u60c5\u51b5\u5c1a\u672a\u786e\u8ba4\uff09<br \/>\nhttps:\/\/pm2.io\/doc\/en\/plus\/quick-start\/<\/p>\n<h1>\u4f7f\u7528\u8bbe\u7f6e\u6587\u4ef6\u8fdb\u884c\u542f\u52a8\u6307\u5b9a<\/h1>\n<p>\u53ef\u4ee5\u4f7f\u7528Yaml\u548cJson\u5c06\u542f\u52a8\u9009\u9879\u914d\u7f6e\u5728\u8bbe\u5b9a\u6587\u4ef6\u4e2d\u5b9a\u4e49\u3002<br \/>\n\u8fd9\u6b21\u6211\u4eec\u5c1d\u8bd5\u4f7f\u7528Yaml\u521b\u5efa\u3002<\/p>\n<pre class=\"post-pre\"><code><span class=\"c1\"># \u30d5\u30a1\u30a4\u30eb\u540d\uff1apm2config.yml\uff08\u30d5\u30a1\u30a4\u30eb\u540d\u306f\u81ea\u7531\u3067\u3059\uff09<\/span>\r\n\r\n<span class=\"na\">name<\/span><span class=\"pi\">:<\/span> <span class=\"s\">slack-bot<\/span>                        <span class=\"c1\"># \u30a2\u30d7\u30ea\u540d<\/span>\r\n<span class=\"na\">script<\/span><span class=\"pi\">:<\/span> <span class=\"s\">main.js<\/span>                        <span class=\"c1\"># \u30b9\u30af\u30ea\u30d7\u30c8\u30d5\u30a1\u30a4\u30eb\u30d1\u30b9<\/span>\r\n<span class=\"na\">watch<\/span><span class=\"pi\">:<\/span> <span class=\"no\">true<\/span>                            <span class=\"c1\"># \u30d5\u30a9\u30eb\u30c0\u3084\u30b5\u30d6\u30d5\u30a9\u30eb\u30c0\u5185\u306e\u30d5\u30a1\u30a4\u30eb\u304c\u5909\u66f4\u3055\u308c\u305f\u5834\u5408\u3001\u30a2\u30d7\u30ea\u306f\u518d\u8aad\u307f\u8fbc\u307f\u3055\u308c\u307e\u3059<\/span>\r\n<span class=\"na\">log-date-format<\/span><span class=\"pi\">:<\/span> <span class=\"s2\">\"<\/span><span class=\"s\">YYYY-MM-DD<\/span> <span class=\"s\">HH:mm<\/span> <span class=\"s\">Z\"<\/span>  <span class=\"c1\"># \u30ed\u30b0\u306b\u65e5\u4ed8\u3092\u8ffd\u52a0<\/span>\r\n\r\n<\/code><\/pre>\n<p>\u5728\u8bbe\u5b9a\u6587\u4ef6\u4e2d\u53ef\u7528\u7684\u9879\u76ee\u8bf7\u53c2\u8003\u4ee5\u4e0b\u94fe\u63a5\uff1ahttps:\/\/pm2.io\/doc\/en\/runtime\/reference\/ecosystem-file\/#apps-options\u3002<\/p>\n<p>\u4f7f\u7528\u914d\u7f6e\u6587\u4ef6\u542f\u52a8<\/p>\n<pre class=\"post-pre\"><code>pm2 start pm2.yml\r\npm2 stop pm2.yml\r\npm2 restart pm2.yml\r\n<\/code><\/pre>\n<h1>\u53c2\u8003\u94fe\u63a5<\/h1>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">[Node.js] PM2\u3092\u7528\u3044\u3066\u672c\u756a\u74b0\u5883\u3067NodeJS\u30a2\u30d7\u30ea\u3092\u52d5\u304b\u3059 &#8211; YoheiM .NET<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">PM2 &#8211; Process File<\/ul>\n","protected":false},"excerpt":{"rendered":"<p>\u56e0\u70ba\u807d\u8aaapm2\u7684\u529f\u80fd\u6bd4forever\u66f4\u5f37\u5927\uff0c\u6240\u4ee5\u6211\u6c7a\u5b9a\u8a66\u8a66\u7528pm2\uff0c\u96d6\u7136\u6211\u4ee5\u524d\u6709\u7528\u904eforever\u3002 \u5b89\u88c5PM [&hellip;]<\/p>\n","protected":false},"author":4,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-31828","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.5 (Yoast SEO v21.5) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u4f7f\u7528PM2\u6765\u8fd0\u884cNode.js\u5e94\u7528 - Blog - Silicon Cloud<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528pm2\u6765\u8fd0\u884cnode-js\u5e94\u7528\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u4f7f\u7528PM2\u6765\u8fd0\u884cNode.js\u5e94\u7528\" \/>\n<meta property=\"og:description\" content=\"\u56e0\u70ba\u807d\u8aaapm2\u7684\u529f\u80fd\u6bd4forever\u66f4\u5f37\u5927\uff0c\u6240\u4ee5\u6211\u6c7a\u5b9a\u8a66\u8a66\u7528pm2\uff0c\u96d6\u7136\u6211\u4ee5\u524d\u6709\u7528\u904eforever\u3002 \u5b89\u88c5PM [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528pm2\u6765\u8fd0\u884cnode-js\u5e94\u7528\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-02-24T13:48:35+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-05-04T05:24:05+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d0ebf37434c4406bed687\/36-0.png\" \/>\n<meta name=\"author\" content=\"\u79d1, \u96c5\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u79d1, \u96c5\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"2 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8pm2%e6%9d%a5%e8%bf%90%e8%a1%8cnode-js%e5%ba%94%e7%94%a8\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8pm2%e6%9d%a5%e8%bf%90%e8%a1%8cnode-js%e5%ba%94%e7%94%a8\/\",\"name\":\"\u4f7f\u7528PM2\u6765\u8fd0\u884cNode.js\u5e94\u7528 - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-02-24T13:48:35+00:00\",\"dateModified\":\"2024-05-04T05:24:05+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/41e222757cdd2a3365361328bd79970a\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8pm2%e6%9d%a5%e8%bf%90%e8%a1%8cnode-js%e5%ba%94%e7%94%a8\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8pm2%e6%9d%a5%e8%bf%90%e8%a1%8cnode-js%e5%ba%94%e7%94%a8\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8pm2%e6%9d%a5%e8%bf%90%e8%a1%8cnode-js%e5%ba%94%e7%94%a8\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u4f7f\u7528PM2\u6765\u8fd0\u884cNode.js\u5e94\u7528\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/\",\"name\":\"Blog - Silicon Cloud\",\"description\":\"\",\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/41e222757cdd2a3365361328bd79970a\",\"name\":\"\u79d1, \u96c5\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/1b2d3e00a7df03689797ebd4af8c5827ba5af936849a71050ec331f4cf902c5d?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/1b2d3e00a7df03689797ebd4af8c5827ba5af936849a71050ec331f4cf902c5d?s=96&d=mm&r=g\",\"caption\":\"\u79d1, \u96c5\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/keya\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8pm2%e6%9d%a5%e8%bf%90%e8%a1%8cnode-js%e5%ba%94%e7%94%a8\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u4f7f\u7528PM2\u6765\u8fd0\u884cNode.js\u5e94\u7528 - Blog - Silicon Cloud","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528pm2\u6765\u8fd0\u884cnode-js\u5e94\u7528\/","og_locale":"zh_CN","og_type":"article","og_title":"\u4f7f\u7528PM2\u6765\u8fd0\u884cNode.js\u5e94\u7528","og_description":"\u56e0\u70ba\u807d\u8aaapm2\u7684\u529f\u80fd\u6bd4forever\u66f4\u5f37\u5927\uff0c\u6240\u4ee5\u6211\u6c7a\u5b9a\u8a66\u8a66\u7528pm2\uff0c\u96d6\u7136\u6211\u4ee5\u524d\u6709\u7528\u904eforever\u3002 \u5b89\u88c5PM [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528pm2\u6765\u8fd0\u884cnode-js\u5e94\u7528\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-02-24T13:48:35+00:00","article_modified_time":"2024-05-04T05:24:05+00:00","og_image":[{"url":"https:\/\/cdn.silicloud.com\/blog-img\/blog\/img\/657d0ebf37434c4406bed687\/36-0.png"}],"author":"\u79d1, \u96c5","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u79d1, \u96c5","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"2 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8pm2%e6%9d%a5%e8%bf%90%e8%a1%8cnode-js%e5%ba%94%e7%94%a8\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8pm2%e6%9d%a5%e8%bf%90%e8%a1%8cnode-js%e5%ba%94%e7%94%a8\/","name":"\u4f7f\u7528PM2\u6765\u8fd0\u884cNode.js\u5e94\u7528 - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-02-24T13:48:35+00:00","dateModified":"2024-05-04T05:24:05+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/41e222757cdd2a3365361328bd79970a"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8pm2%e6%9d%a5%e8%bf%90%e8%a1%8cnode-js%e5%ba%94%e7%94%a8\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8pm2%e6%9d%a5%e8%bf%90%e8%a1%8cnode-js%e5%ba%94%e7%94%a8\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8pm2%e6%9d%a5%e8%bf%90%e8%a1%8cnode-js%e5%ba%94%e7%94%a8\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"\u4f7f\u7528PM2\u6765\u8fd0\u884cNode.js\u5e94\u7528"}]},{"@type":"WebSite","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website","url":"https:\/\/www.silicloud.com\/zh\/blog\/","name":"Blog - Silicon Cloud","description":"","inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/41e222757cdd2a3365361328bd79970a","name":"\u79d1, \u96c5","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/1b2d3e00a7df03689797ebd4af8c5827ba5af936849a71050ec331f4cf902c5d?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/1b2d3e00a7df03689797ebd4af8c5827ba5af936849a71050ec331f4cf902c5d?s=96&d=mm&r=g","caption":"\u79d1, \u96c5"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/keya\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8pm2%e6%9d%a5%e8%bf%90%e8%a1%8cnode-js%e5%ba%94%e7%94%a8\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/31828","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/users\/4"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=31828"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/31828\/revisions"}],"predecessor-version":[{"id":98578,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/31828\/revisions\/98578"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=31828"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=31828"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=31828"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}