使用PM2,在生产环境稳定运行你的node项目

PM2

一个 node,本身就用几行代码,就可以启动个 server 进程,监听个端口,为大家提供 Web 服务

一、依赖安装

npm install pm2 -g

二、命令行启动

  1. 普通执行启动

    pm2 start <js 文件路径 >.js

  2. 携带参数启动

    pm2 start < 某种方式 > -- --param_name param_value

  3. npm 脚本启动

    pm2 start npm -- run

    pm2 start yarn -- run

🌰 举个例子

  • 项目结构
  • 普通启动
  • npm 脚本命令启动

三、配置文件启动

  1. pm2 配置文件生成

    pm2 init

  1. 配置文件属性
javascript 复制代码
// ecosystem.config.js

module.exports = {
  apps : [{
    name: 'levenx-world', //pm2启动项目名称
    script: 'app.js', //启动脚本入口  ( npm run start )
    args: 'one two', // 启动脚本参数
    instances: 1, //启动实例个数 (max)
    autorestart: true, //自动启动
    watch: false, //是否开启watch模式
    max_memory_restart: '1G',//最大内存
    env: { //环境配置
      NODE_ENV: 'development'
    },
    env_production: {
      NODE_ENV: 'production'
    }
  }],
};
  1. 配置文件启动

    npm run ecosystem.config.js

四、项目自动化部署

通过一行命令, pm2 工具自动化部署项目到云服务。

  1. 配置文件

    javascript 复制代码
    module.exports = {
      deploy : {
        production : {
          user : 'levex', //服务器用户名
          host : 'localhost', //服务器localhost
          ref  : 'origin/master', //git分支
          repo : 'git@github.com:repo.git', //git 地址
          path : '/Users/levenx/Desktop', // 服务器源码存储地址
          'post-deploy' : 'npm install && pm2 reload ecosystem.config.js --env production' //部署脚本
        }
      }
    };
  2. 初始化项目部署

    pm2 deploy apps init

  3. 项目部署更新

    pm2 deploy apps update

相关推荐
Cosmoshhhyyy6 小时前
Node.js 18+安装及Claude国内镜像使用、idea中claude插件下载指南
node.js
徐_三岁12 小时前
关于npm的钩子函数
前端·npm·node.js
不买Huracan不改名15 小时前
安装Codex(需要用npm)
前端·npm·node.js
光影少年15 小时前
webpack和vite优化方案都有哪些
前端·webpack·node.js
kk不中嘞15 小时前
Webpack 核心原理剖析
前端·webpack·node.js
Yvonne爱编码15 小时前
简述ajax、node.js、webpack、git
前端·git·ajax·webpack·node.js·visual studio
摘星编程17 小时前
ChatGPT 协作排查:Node.js 内存泄漏的定位与修复
chatgpt·性能优化·node.js·ai辅助调试·chatgpt协作
前端双越老师19 小时前
前端开发 AI Agent 智能体,需要掌握哪些知识?
前端·node.js·agent
EndingCoder19 小时前
Electron 安全性最佳实践:防范常见漏洞
前端·javascript·electron·前端框架·node.js·桌面端
醉方休1 天前
npm/pnpm软链接的优点和使用场景
前端·npm·node.js