PM2 node进程管理工具 自动部署小结-阿里云开发者社区

开发者社区> 开发与运维> 正文

PM2 node进程管理工具 自动部署小结

简介: PM2 的功能不多做介绍了,总之使用简单,功能强大。 今天实现了本地自动部署node项目到服务器的流程。简单总结下几个注意点。 建议先看 文档 先要保证要部署的服务器上(以下简称server)能直接ssh拉仓库代码,比如 git clone git@gitee.com:finley/demo.git。

PM2 的功能不多做介绍了,总之使用简单,功能强大。
今天实现了本地自动部署node项目到服务器的流程。简单总结下几个注意点。
建议先看 文档

  1. 先要保证要部署的服务器上(以下简称server)能直接ssh拉仓库代码,比如 git clone git@gitee.com:finley/demo.git。不行的话配下server生成ssh-key,然后把public key告诉代码仓库服务商,比如coding.net, github。
  2. 权限问题,比如server的登录用户是Ubuntu,将来项目要部署在/home/ubuntu下面,可以执行下 sudo chown ubuntu:ubuntu /home/ubuntu/.pm2/* 不然可能会部署失败。
  3. 部署成功后会在配置的项目路径里出现以下三个目录:

current -- 当前服务运行的文件夹(是source的软链接)
share -- log pid 等共享数据
source -- clone 下来的源代码

  1. 配置脚本
module.exports = {
  /**
   * Application configuration section
   * http://pm2.keymetrics.io/docs/usage/application-declaration/
   */
  apps : [
    {
      name      : 'NODE-API',
      script    : 'server.js',
      env_development: {
        NODE_ENV: 'development',
        SERVER_PORT: 8081,
        LOGSTASH_URL: 'http://localhost/finley/PHP/test.php'
      },
      env_production : {
        NODE_ENV: 'production',
        SERVER_PORT: 8081,
        LOGSTASH_URL: 'http://192.168.100.16:9700'
      }
    }
  ],

  /**
   * Deployment section
   * http://pm2.keymetrics.io/docs/usage/deployment/
   */
  deploy : {
    // 项目信息
    // 下面的配置是我用什么用户登录哪个服务器,从哪拉代码,项目存到什么位置。拉完执行的脚本是啥
    'node1' : {
      user : 'ubuntu',
      // 写成数组,可以同时部署到多台服务器
      host : '119.254.xxx.xxx',
      ref  : 'origin/develop',
      repo : 'ssh://git@demo.com/demo.git',
      // 项目的存放地址,会生成current, source, share目录
      path : '/home/ubuntu/node-project',
      // "ssh_options": ["StrictHostKeyChecking=no", "PasswordAuthentication=no"],
      "post-deploy" : 'npm install && pm2 startOrRestart ecosystem.config.js --env production'
    }
  }
};
  1. 执行命令, 如果是windows,在CMD中执行没用,建议在git bash下执行。
    node1就是要部署的项目名称
    pm2 deploy ecosystem.config.js node1 setup
    这个命令只是拉仓库代码
    pm2 deploy ecosystem.config.js node1
    执行这个命令会执行 post-deploy,运行项目

pm2 reload 和pm2 restart 有啥区别

官方说明:As opposed to restart, which kills and restarts the process, reload achieves a 0-second-downtime reload.
简单理解:
restart = stop+start
reload = 重新读取配置文件
具体用哪个要根据项目运行实际情况,有些项目需要7*24运行,不得stop,这时候用reload比较好。

版权声明:本文首发在云栖社区,遵循云栖社区版权声明:本文内容由互联网用户自发贡献,版权归用户作者所有,云栖社区不为本文内容承担相关法律责任。云栖社区已升级为阿里云开发者社区。如果您发现本文中有涉嫌抄袭的内容,欢迎发送邮件至:developer2020@service.aliyun.com 进行举报,并提供相关证据,一经查实,阿里云开发者社区将协助删除涉嫌侵权内容。

分享:
开发与运维
使用钉钉扫一扫加入圈子
+ 订阅

集结各类场景实战经验,助你开发运维畅行无忧

其他文章