pm2學習備忘

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
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章