使用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

相关推荐
年纪轻轻就扛不住32 分钟前
Express 入门指南(超详细教程)
前端·前端框架·node.js·express·js
爱电摇的小码农2 小时前
【深度探究系列(5)】:前端开发打怪升级指南:从踩坑到封神的解决方案手册
前端·javascript·css·vue.js·node.js·html5·xss
Tttian6223 小时前
npm init vue@latestnpm error code ETIMEDOUT
前端·vue.js·npm
lihainuo5 小时前
Next.js + AI-SDK 实战:模型注册表从类型设计到工具调用全解析
后端·node.js
胡gh5 小时前
JavaScript 中的闭包、防抖与节流:让你彻底搞懂它们的作用和应用场景
前端·javascript·node.js
野槐6 小时前
vue3+node.js+mysql写接口(二)
node.js
讨厌吃蛋黄酥6 小时前
🚀 全栈开发48小时逆袭:用Node.js打造超炫实时数据仪表盘! 📊
node.js·全栈
天若有情6736 小时前
Node.js 是什么?npm 是什么? Vue 为什么需要他们?
vue.js·npm·node.js
爱敲代码的小冰7 小时前
npm 切换 node 版本 和npm的源
前端·npm·node.js
梁辰兴8 小时前
企业培训笔记:Vue3前端框架配置
笔记·前端框架·npm·vue·vue3·node