欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用pm2部署node生產(chǎn)環(huán)境的方法步驟

 更新時(shí)間:2019年03月09日 09:48:44   作者:keywords  
這篇文章主要介紹了使用pm2部署node生產(chǎn)環(huán)境的方法步驟,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

一、PM2是什么

  • 是可以用于生產(chǎn)環(huán)境的Nodejs的進(jìn)程管理工具,并且它內(nèi)置一個(gè)負(fù)載均衡。它不僅可以保證服務(wù)不會(huì)中斷一直在線,并且提供0秒reload功能,還有其他一系列進(jìn)程管理、監(jiān)控功能。并且使用起來非常簡(jiǎn)單。
  • 嗯嗯,最好的用處就是監(jiān)控我們的生產(chǎn)環(huán)境下的node程序運(yùn)行狀態(tài),讓它給我們?nèi)找岳^日的處于工作狀態(tài)。
  • pm2官方文檔

二、為森么要使用pm2

  • 原始社會(huì)的我們開發(fā)node服務(wù)端程序一般過程:
    • 編寫好node程序app.js,運(yùn)行node app.js;或者寫入script使用npm運(yùn)行;打開瀏覽器訪問;
    • 好像需要修改內(nèi)容,瀏覽器對(duì)修改的內(nèi)容沒有顯示出來?->node app.js->再次運(yùn)行;
    • 瀏覽器忽然訪問不到服務(wù),好像出錯(cuò)啦?重啟下->node app.js->再次運(yùn)行;
    • 哎呀開了好多控制臺(tái)窗口,一不小心關(guān)閉了,服務(wù)又訪問不到了,繼續(xù)打開控制臺(tái)->node app.js->再次運(yùn)行;
  • 好崩潰!好像有個(gè)工具nodemon;安裝使用nodemon app.js;哇,可以自動(dòng)監(jiān)聽文件修改變化自動(dòng)重啟,但是關(guān)閉控制臺(tái)服務(wù)還是會(huì)被摧毀。
  • 通過這個(gè)很常用的場(chǎng)景,我們了解到要避免這些麻煩一個(gè)服務(wù)器至少需要有:后臺(tái)運(yùn)行和自動(dòng)重啟,這兩個(gè)能力。
  • 再來看看使用pm2可擁有的能力:
    • 日志管理;兩種日志,pm2系統(tǒng)日志與管理的進(jìn)程日志,默認(rèn)會(huì)把進(jìn)程的控制臺(tái)輸出記錄到日志中;
    • 負(fù)載均衡:PM2可以通過創(chuàng)建共享同一服務(wù)器端口的多個(gè)子進(jìn)程來擴(kuò)展您的應(yīng)用程序。這樣做還允許以零秒停機(jī)時(shí)間重新啟動(dòng)應(yīng)用程序。
    • 終端監(jiān)控:可以在終端中監(jiān)控應(yīng)用程序并檢查應(yīng)用程序運(yùn)行狀況(CPU使用率,使用的內(nèi)存,請(qǐng)求/分鐘等)。
    • SSH部署:自動(dòng)部署,避免逐個(gè)在所有服務(wù)器中進(jìn)行ssh。
    • 靜態(tài)服務(wù):支持靜態(tài)服務(wù)器功能
    • 支持開發(fā)調(diào)試模式,非后臺(tái)運(yùn)行,pm2-dev start <appName>;
    • 。。。。。太過強(qiáng)大!

pm2常用命令

啟動(dòng)服務(wù)pm2 start <script_file|config_file> [options] 啟動(dòng)指定應(yīng)用

pm2 start app.js        //啟動(dòng)app.js應(yīng)用
pm2 start app.js --name app  //啟動(dòng)應(yīng)用并設(shè)置name
pm2 start app.sh        //腳本啟動(dòng)

pm2 start app.js --watch  //監(jiān)聽模式啟動(dòng),當(dāng)文件發(fā)生變化,自動(dòng)重啟

//max 表示PM2將自動(dòng)檢測(cè)可用CPU的數(shù)量并運(yùn)行盡可能多的進(jìn)程
//max可以自定義,如果是4核CPU,設(shè)置為2則占用2個(gè)
pm2 start app.js -i max //啟用群集模式(自動(dòng)負(fù)載均衡)

pm2-dev start ... // 開發(fā)模式啟動(dòng),即不啟用后臺(tái)運(yùn)行

查看啟動(dòng)列表pm2 list

顯示應(yīng)用程序詳細(xì)信息pm2 show <appName> [options] 顯示指定應(yīng)用詳情

pm2 show [Name]   //根據(jù)name查看
pm2 show [ID]    //根據(jù)id查看

停止指定應(yīng)用pm2 stop <appName> [options] 停止指定應(yīng)用

pm2 stop all        //停止所有應(yīng)用
pm2 stop [AppName]    //根據(jù)應(yīng)用名停止指定應(yīng)用
pm2 stop [ID]       //根據(jù)應(yīng)用id停止指定應(yīng)用

重啟應(yīng)用pm2 reload|restart <appName> [options] 重啟指定應(yīng)用

pm2 restart app.js    //同時(shí)殺死并重啟所有進(jìn)程,短時(shí)間內(nèi)服務(wù)不可用,生成環(huán)境慎用
pm2 reload app.js    //重新啟動(dòng)所有進(jìn)程,0秒重啟,始終保持至少一個(gè)進(jìn)程在運(yùn)行
pm2 gracefulReload all  //以群集模式重新加載所有應(yīng)用程序

啟動(dòng)靜態(tài)服務(wù)器pm2 serve ./dist 8080將目錄dist作為靜態(tài)服務(wù)器根目錄,端口為8080

刪除應(yīng)用pm2 delete <appName> [options] 刪除指定應(yīng)用;如果修改了應(yīng)用配置行為,需要先刪除應(yīng)用,重新啟動(dòng)后方才會(huì)生效,如修改腳本入口文件;

pm2 delete all        //關(guān)閉并刪除應(yīng)用
pm2 delete [AppName]    //根據(jù)應(yīng)用名關(guān)閉并刪除應(yīng)用
pm2 delete [ID]      //根據(jù)應(yīng)用ID關(guān)閉并刪除應(yīng)用

pm2 kill 殺掉pm2管理的所有進(jìn)程;

pm2 logs <appName> 查看指定應(yīng)用的日志,即標(biāo)準(zhǔn)輸出和標(biāo)準(zhǔn)錯(cuò)誤

pm2 logs      //查看所有應(yīng)用日志
pm2 logs [Name]  //根據(jù)指定應(yīng)用名查看應(yīng)用日志
pm2 logs [ID]   //根據(jù)指定應(yīng)用ID查看應(yīng)用日志

pm2 monit 監(jiān)控各個(gè)應(yīng)用進(jìn)程cpu和memory使用情況;

PM2配置方式

命令生產(chǎn)默認(rèn)示例配置文件pm2 ecosystem或pm2 init,運(yùn)行默認(rèn)會(huì)生成ecosystem.config.js配置文件

module.exports = {
 apps: [
  {
   name: 'back-Api',   //應(yīng)用名
   script: './server/start.js',  //應(yīng)用文件位置
   env: {
    PM2_SERVE_PATH: "./apidoc",  //靜態(tài)服務(wù)路徑
    PM2_SERVE_PORT: 8080,  //靜態(tài)服務(wù)器訪問端口
    NODE_ENV: 'development' //啟動(dòng)默認(rèn)模式
   },
   env_production : {
    NODE_ENV: 'production' //使用production模式 pm2 start ecosystem.config.js --env production
   },
   instances:"max",     //將應(yīng)用程序分布在所有CPU核心上,可以是整數(shù)或負(fù)數(shù)
   instance_var: "INSTANCE_ID",
   exec_mode: "cluster",
   watch:[
    "server",
   ], //監(jiān)聽模式,不能單純的設(shè)置為true,易導(dǎo)致無限重啟,因?yàn)槿罩疚募谧兓?,需要排除?duì)其的監(jiān)聽
   merge_logs: true,     //集群情況下,可以合并日志
  }
 ],
 deploy: {
   production : {
    user: 'node',           //ssh 用戶
    host: '212.83.163.1',       //ssh 地址
    ref: 'origin/master',       //GIT遠(yuǎn)程/分支
    repo: 'git@github.com:repo.git',  //git地址
    path: '/var/www/production',    //服務(wù)器文件路徑
    "post-deploy": 'npm install && pm2 reload ecosystem.config.js --env production' //部署后的動(dòng)作
   }
 }
}; 

自定義json配置文件如:processes.json;啟動(dòng)pm2 start processes.json

  {
   "apps": [{
    "name": "app", //名稱
    "script": "./", //程序入口
    "cwd": "./",      //根目錄
    "watch":[
      "views"
    ],//需要監(jiān)控的目錄
    "error_file":"./logs/err.log",//錯(cuò)誤輸出日志
    "out_file":"./logs/out.log", //日志
    "log_date_format":"YYYY-MM-DD HH:mm Z" //日期格式
    }]
  }

pm2常用配置項(xiàng)解析

1. apps:json結(jié)構(gòu),apps是一個(gè)數(shù)組,每一個(gè)數(shù)組成員就是對(duì)應(yīng)一個(gè)pm2中運(yùn)行的應(yīng)用

2. name:應(yīng)用程序名稱"app"

3. cwd:應(yīng)用程序所在的目錄"./"

4. script:應(yīng)用程序的腳本路徑"./"

5. log_date_format: 日志文件名輸出日期格式"YYYY-MM-DD HH:mm Z"

6. error_file:自定義應(yīng)用程序的錯(cuò)誤日志文件"./logs/app-err.log",

7. out_file:自定義應(yīng)用程序日志文件"./logs/app-out.log"

8. instances: 應(yīng)用啟動(dòng)實(shí)例個(gè)數(shù),僅在cluster模式有效 默認(rèn)為fork;或者 max

9. min_uptime:最小運(yùn)行時(shí)間,這里設(shè)置的是60s即如果應(yīng)用程序在60s內(nèi)退出,pm2會(huì)認(rèn)為程序異常退出,此時(shí)觸發(fā)重啟max_restarts設(shè)置數(shù)量

10. max_restarts:設(shè)置應(yīng)用程序異常退出重啟的次數(shù),默認(rèn)15次(從0開始計(jì)數(shù))

11. cron_restart:定時(shí)啟動(dòng),解決重啟能解決的問題

12. watch:是否啟用監(jiān)控模式,默認(rèn)是false。如果設(shè)置成true,當(dāng)應(yīng)用程序變動(dòng)時(shí),pm2會(huì)自動(dòng)重載。這里也可以設(shè)置你要監(jiān)控的文件。

13. "ignore_watch": [                           // 不用監(jiān)聽的文件
            "node_modules",
            "logs"
        ],
13. merge_logs:// 設(shè)置追加日志而不是新建日志

14. exec_interpreter:應(yīng)用程序的腳本類型,這里使用的shell,默認(rèn)是nodejs

15. exec_mode:應(yīng)用程序啟動(dòng)模式,這里設(shè)置的是cluster_mode(集群),默認(rèn)是fork

16. autorestart:啟用/禁用應(yīng)用程序崩潰或退出時(shí)自動(dòng)重啟,默認(rèn)為true, 發(fā)生異常的情況下自動(dòng)重啟

17. vizion:啟用/禁用vizion特性(版本控制)

18. "args": "", // 傳遞給腳本的參數(shù)

19. env: {
        PM2_SERVE_PATH: "./apidoc",    //靜態(tài)服務(wù)路徑
        PM2_SERVE_PORT: 8080,   //靜態(tài)服務(wù)器訪問端口
        NODE_ENV: 'development' //啟動(dòng)默認(rèn)模式
      },

20. env_production : {
        NODE_ENV: 'production'  //使用production模式 pm2 start ecosystem.config.js --env production
      },

pm2配合log4js處理日志

1、pm2啟動(dòng)時(shí)通常會(huì)發(fā)現(xiàn)log4js記錄不到日志信息;

2、解決方案,安裝pm2的pm2-intercom進(jìn)程間通信模塊

3、在log4js的配置文件logger.js里添加如下命令:

pm2: true, 
pm2InstanceVar: 'INSTANCE_ID' 

4、pm2配置文件中添加"instance_var": "INSTANCE_ID", // 添加這一行 字段

5、發(fā)現(xiàn)如果沒有設(shè)置群集模式"exec_mode": "cluster",也會(huì)記錄不到;

其他

log4js日志配置使用詳情Koa日志中間件封裝開發(fā)(log4js)

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 在node中如何使用 ES6

    在node中如何使用 ES6

    這篇文章主要介紹了在node中如何使用 ES6 ,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-04-04
  • 使用nvm管理不同版本的node與npm的方法

    使用nvm管理不同版本的node與npm的方法

    本篇文章主要介紹了使用 nvm 管理不同版本的 node 與 npm的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-10-10
  • 原生nodejs使用websocket代碼分享

    原生nodejs使用websocket代碼分享

    本文給大家分享的是在原生的nodejs中如何使用websocket實(shí)現(xiàn)信息傳輸,非常實(shí)用,有需要的小伙伴可以參考下
    2018-04-04
  • 使用Node.js實(shí)現(xiàn)Clean?Architecture方法示例詳解

    使用Node.js實(shí)現(xiàn)Clean?Architecture方法示例詳解

    這篇文章主要為大家介紹了使用Node.js實(shí)現(xiàn)Clean?Architecture方法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-02-02
  • Nodejs中執(zhí)行的shell命令的代碼分享

    Nodejs中執(zhí)行的shell命令的代碼分享

    雖然nodejs運(yùn)行時(shí)提供了和OS交互的諸多API命令,但是有些操作(例如:特定系統(tǒng)信息獲?。┻€是使用shell命令更加方便一些,下面就跟隨小編一起來看看有哪些是宜在nodejs中執(zhí)行的shell代碼吧
    2024-02-02
  • 詳解nodejs 文本操作模塊-fs模塊(四)

    詳解nodejs 文本操作模塊-fs模塊(四)

    本篇文章詳細(xì)的講訴fa.fstat方法,這個(gè)State對(duì)象中,包含的數(shù)據(jù)都有哪些,并且他們分別代表的含義是什么。具有一定的參考價(jià)值,有興趣的可以了解一下。
    2016-12-12
  • nodejs如何在typescript項(xiàng)目中申明全局變量

    nodejs如何在typescript項(xiàng)目中申明全局變量

    這篇文章主要介紹了nodejs在typescript項(xiàng)目中申明全局變量,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2024-05-05
  • nodejs+socket.io實(shí)現(xiàn)p2p消息實(shí)時(shí)發(fā)送的項(xiàng)目實(shí)踐

    nodejs+socket.io實(shí)現(xiàn)p2p消息實(shí)時(shí)發(fā)送的項(xiàng)目實(shí)踐

    本文主要介紹了nodejs+socket.io實(shí)現(xiàn)p2p消息實(shí)時(shí)發(fā)送,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • node中如何使用redis的實(shí)現(xiàn)

    node中如何使用redis的實(shí)現(xiàn)

    本文主要介紹了node中如何使用redis的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • 配置node服務(wù)器并且鏈接微信公眾號(hào)接口配置步驟詳解

    配置node服務(wù)器并且鏈接微信公眾號(hào)接口配置步驟詳解

    這篇文章主要介紹了配置node服務(wù)器并且鏈接微信公眾號(hào)接口配置步驟詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,,需要的朋友可以參考下
    2019-06-06

最新評(píng)論