目錄
pm2 是什麼
pm2基本指令
总结
首頁 web前端 js教程 深入聊聊Node進程管理工具-pm2的使用方法

深入聊聊Node進程管理工具-pm2的使用方法

Apr 19, 2023 pm 06:59 PM
node.js node

如何使用Node進程管理工具-pm2,以下這篇文章帶大家聊聊Node進程管理工具-pm2的使用方法,希望對大家有幫助!

深入聊聊Node進程管理工具-pm2的使用方法

pm2 是什麼

pm2 是一個守護程式管理工具,它能幫你守護和管理你的應用程式。通常一般會在服務上線的時候使用 pm2 來管理。 pm2 能做的其實有很多,比如監聽文件改動自動重啟,統一管理多個進程,內置的負載平衡,日誌系統等等,下面就讓我們看下pm2 是如何使用的吧

pm2基本指令

首先我們先建立一個簡單的node 服務,新資料夾執行npm init,然後裝pm2

npm i pm2 -g
登入後複製

新index.js 和index2.js,寫兩個簡單的http 服務,然後用pm2 進行管理。 【相關教學推薦:nodejs影片教學程式設計教學

//index.js
let http = require("http");
let server = http.createServer();
server.on("request", function (req, res) {
  console.log("------------------enter");
  res.write("hello juejin");
  res.end();
});

server.listen(3000, function () {
  console.log(`服务器启动成功,通过http://localhost:3000/进行访问`);
});
登入後複製
//index2.js
let http = require("http");
let server = http.createServer();
server.on("request", function (req, res) {
  console.log("------------------enter2");
  res.write("hello juejin2");
  res.end();
});

server.listen(3001, function () {
  console.log(`服务器启动成功,通过http://localhost:3001/进行访问`);
});
登入後複製

接下來我們將使用pm2 的第一個指令: pm2 start index. jspm2 start index2.js 分別啟動這兩個程式

深入聊聊Node進程管理工具-pm2的使用方法

#當然如果你想指定一個行程名字可以這樣: pm2 start -n test index.js,如果你想監聽檔案改變可以加--watch等等

訪問http://localhost:3000/

深入聊聊Node進程管理工具-pm2的使用方法

執行pm2 log可以看到我們列印的日誌

深入聊聊Node進程管理工具-pm2的使用方法

pm2的命令還有很多,下面列舉幾個

  • 停止1 個/多個/所有程式pm2 stop id/id1 id2 id3/all
  • 殺死1 個/多個/所有程式pm2 delete id/id1 id2 id3/all
  • 重啟1 個/多個/所有程式pm2 restart id/id1 id2 id3/ all
  • 啟動並查看日誌pm2 start api.js --attach
  • 列出應用程式##pm2 list
  • 查看監控面板
  • pm2 monit##查看程式資料
  • pm2 show [id]
  • ##負載平衡
我們都知道NodeJS 是一個非同步單執行緒語言,倘若不做任何處理直接部署到伺服器上,那麼它也只能使用伺服器的一個執行緒,這樣是非常浪費效能的。

使用pm2 只要一個指令就能讓我們的程式充分利用伺服器的CPU,拿index.js 為例:

pm2 start index -i max

,例如我的電腦是10核20 線程,它就會開20 個線程

當然如果你想指定多少線程可以直接將max 改成你想開的線程數深入聊聊Node進程管理工具-pm2的使用方法pm2 start index -i 3

設定檔深入聊聊Node進程管理工具-pm2的使用方法

上面的例子我們都是使用命令列進行管理的,這樣其實挺不方便的,好在pm2 提供了設定檔的形式。

我們直接使用命令

pm2 init simple

即可產生一個簡單的設定檔

ecosystem.config.js,修改一下讓它指向我們的兩個服務

module.exports = {
  apps: [
    {
      name: "index",
      script: "./index.js",
    },
    {
      name: "index2",
      script: "./index2.js",
    },
  ],
};
登入後複製
然後我們將原先的程序都kill 掉,執行pm2 start ecosystem.config.js

,同樣的我們的兩個服務都被啟動了

#下面列舉一些設定項深入聊聊Node進程管理工具-pm2的使用方法ecosystem.config.js

module.exports = {
  apps: [
    {
      name: "index", //name
      script: "./index.js", //相对于pm2 start 的相对路径
      cwd: "", //要启动的应用程序的目录
      instances: 2, //要启动实例的数量,就是上面提到的负载
      watch: true, //是否启动监听
      env: { NODE_ENV: "development" }, //	将出现在您的应用程序中的 env 变量
      env_xxx: {
        NODE_ENV: "xxx", //使用pm2注入xxx变量进行切换
      },
      log_date_format: "YYYY-MM-DD HH:mm Z", //日志时间格式
      error_file: "./log/index-error.log", //错误文件路径
      out_file: "./log/index-out.log", //输出日志文件路径
      max_restarts: 10, //最大重启数
      restart_delay: 4000, //重启延迟时间ms
      autorestart: true, //是否自动重启
      cron_restart: "", //定时重启 使用cron表达式
    },
    {
      name: "index2",
      script: "./index2.js",
    },
  ],
};
登入後複製
日誌

日誌對於後端排查錯誤是非常重要的,pm2 自帶日誌功能,例如我們在上面設定檔中配置了日誌相關的參數

log_date_format: "YYYY-MM-DD HH:mm Z", //日志时间格式
error_file: "./log/index-error.log", //错误文件路径
out_file: "./log/index-out.log", //输出日志文件路径
登入後複製

當我們啟動專案的時候,日誌就會記錄在log 下

pm2 自帶的日誌功能是不支援日誌分割的。隨著時間的推移,日誌檔案會越來越大,不僅會影響效能,後期排查問題也十分麻煩,因此我們需要對日誌進行分割。日誌分割操作很簡單,只需要安裝深入聊聊Node進程管理工具-pm2的使用方法pm2-logrotate

外掛程式即可,注意這裡是pm2 install

pm2 install pm2-logrotate
登入後複製
然後執行pm2 conf 可以看到相關設定

#解釋一下相關意義深入聊聊Node進程管理工具-pm2的使用方法

  • Compress:是否通过 gzip 压缩日志

  • max_size:单个日志文件的大小

  • retain:保留的日志文件个数

  • dateFormat:日志文件名中的日期格式,默认是 YYYY-MM-DD_HH-mm-ss

  • rotateModule:是否把 pm2 本身的日志也进行分割,

  • workerInterval:检查文件时间间隔

  • rotateInterval:设置强制分割,默认值是 0 0 * * *,意思是每天晚上 0 点分割,这里使用的是 corn 表达式,不会的可以搜索一下

如果我们想要配置也很简单,比如修改 max_size

pm2 set pm2-logrotate:max_size 1K
登入後複製

然后我们简单测试一下这个工具,我们先设置每个 log 文件最大 1kb

然后重启我们的项目

pm2 restart ecosystem.config.js
登入後複製

然后就会发现我们的日志被分割了

深入聊聊Node進程管理工具-pm2的使用方法

总结

pm2对于node服务的管理是十分方便的,文中提到的只是其中一部分,如果你想使用pm2管理你的服务的话可以到官网pm2.io/ 进行学习

更多node相关知识,请访问:nodejs 教程

以上是深入聊聊Node進程管理工具-pm2的使用方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

一文聊聊Node中的記憶體控制 一文聊聊Node中的記憶體控制 Apr 26, 2023 pm 05:37 PM

基於無阻塞、事件驅動建立的Node服務,具有記憶體消耗低的優點,非常適合處理海量的網路請求。在海量請求的前提下,就需要考慮「記憶體控制」的相關問題了。 1. V8的垃圾回收機制與記憶體限制 Js由垃圾回收機

圖文詳解Node V8引擎的記憶體和GC 圖文詳解Node V8引擎的記憶體和GC Mar 29, 2023 pm 06:02 PM

這篇文章帶大家深入了解NodeJS V8引擎的記憶體和垃圾回收器(GC),希望對大家有幫助!

node專案中如何使用express來處理檔案的上傳 node專案中如何使用express來處理檔案的上傳 Mar 28, 2023 pm 07:28 PM

怎麼處理文件上傳?以下這篇文章為大家介紹一下node專案中如何使用express來處理文件的上傳,希望對大家有幫助!

深入聊聊Node中的File模組 深入聊聊Node中的File模組 Apr 24, 2023 pm 05:49 PM

文件模組是對底層文件操作的封裝,例如文件讀寫/打開關閉/刪除添加等等文件模組最大的特點就是所有的方法都提供的**同步**和**異步**兩個版本,具有sync 字尾的方法都是同步方法,沒有的都是異

深入淺析Node的進程管理工具'pm2” 深入淺析Node的進程管理工具'pm2” Apr 03, 2023 pm 06:02 PM

這篇文章跟大家分享Node的進程管理工具“pm2”,聊聊為什麼需要pm2、安裝和使用pm2的方法,希望對大家有幫助!

Pi Node教學:什麼是Pi節點?如何安裝和設定Pi Node? Pi Node教學:什麼是Pi節點?如何安裝和設定Pi Node? Mar 05, 2025 pm 05:57 PM

PiNetwork節點詳解及安裝指南本文將詳細介紹PiNetwork生態系統中的關鍵角色——Pi節點,並提供安裝和配置的完整步驟。 Pi節點在PiNetwork區塊鏈測試網推出後,成為眾多先鋒積極參與測試的重要環節,為即將到來的主網發布做準備。如果您還不了解PiNetwork,請參考Pi幣是什麼?上市價格多少? Pi用途、挖礦及安全性分析。什麼是PiNetwork? PiNetwork項目始於2019年,擁有其專屬加密貨幣Pi幣。該項目旨在創建一個人人可參與

一起聊聊Node中的事件循環 一起聊聊Node中的事件循環 Apr 11, 2023 pm 07:08 PM

事件循環是 Node.js 的基本組成部分,透過確保主執行緒不被阻塞來實現非同步編程,了解事件循環對建立高效應用程式至關重要。以下這篇文章就來帶大家深入了解Node中的事件循環 ,希望對大家有幫助!

node無法用npm指令怎麼辦 node無法用npm指令怎麼辦 Feb 08, 2023 am 10:09 AM

node無法用npm指令是因為沒有正確配置環境變量,其解決方法是:1、開啟“系統屬性”;2、找到“環境變數”->“系統變數”,然後編輯環境變數;3、找到nodejs所在的資料夾;4、點選「確定」即可。

See all articles