pm2官網https://pm2.keymetrics.io/docs/usage/application-declaration/
啓動腳本,傳遞參數:
pm2 start start.json --env=prod
{
app: [
{
name: "ota-server",
script: "./ota_server/bin/www",
watch: false,
env_prod: {
"NODE_ENV": "production",
},
env_dev: {
"NODE_ENV": "development",
}
}
],
}
pm2 完整配置文件:
{
"apps": {
"name": "wuwu", // 項目名
"script": "./bin/www", // 執行文件
"cwd": "./", // 根目錄
"args": "", // 傳遞給腳本的參數
"interpreter": "", // 指定的腳本解釋器
"interpreter_args": "", // 傳遞給解釋器的參數
"watch": true, // 是否監聽文件變動然後重啓
"ignore_watch": [ // 不用監聽的文件
"node_modules",
"logs"
],
"exec_mode": "cluster_mode", // 應用啓動模式,支持fork和cluster模式
"instances": 4, // 應用啓動實例個數,僅在cluster模式有效 默認爲fork;或者 max
"max_memory_restart": 8, // 最大內存限制數,超出自動重啓
"error_file": "./logs/app-err.log", // 錯誤日誌文件
"out_file": "./logs/app-out.log", // 正常日誌文件
"merge_logs": true, // 設置追加日誌而不是新建日誌
"log_date_format": "YYYY-MM-DD HH:mm:ss", // 指定日誌文件的時間格式
"min_uptime": "60s", // 應用運行少於時間被認爲是異常啓動
"max_restarts": 30, // 最大異常重啓次數,即小於min_uptime運行時間重啓次數;
"autorestart": true, // 默認爲true, 發生異常的情況下自動重啓
"cron_restart": "", // crontab時間格式重啓應用,目前只支持cluster模式;
"restart_delay": "60s" // 異常重啓情況下,延時重啓時間
"env": {
"NODE_ENV": "production", // 環境參數,當前指定爲生產環境 process.env.NODE_ENV
"REMOTE_ADDR": "愛上大聲地" // process.env.REMOTE_ADDR
},
"env_dev": {
"NODE_ENV": "development", // 環境參數,當前指定爲開發環境 pm2 start app.js --env_dev
"REMOTE_ADDR": ""
},
"env_test": { // 環境參數,當前指定爲測試環境 pm2 start app.js --env_test
"NODE_ENV": "test",
"REMOTE_ADDR": ""
}
}
}
腳步操作命令
# Start all applications
pm2 start ecosystem.config.js
# Stop all
pm2 stop ecosystem.config.js
# Restart all
pm2 restart ecosystem.config.js
# Reload all
pm2 reload ecosystem.config.js
# Delete all
pm2 delete ecosystem.config.js
pm2啓動靜態文件服務
pm2 可以直接當一個靜態web服務器使用。具體使用命令爲:
pm2 server [跟目錄] [端口] --name [pm2名稱]
// 案例:啓動 /srv/myBolb/ 目錄下的文件爲靜態服務器,端口是18080
pm2 serve /srv/myBolb/ 18080 --name myBolb