zoukankan      html  css  js  c++  java
  • 在生产环境中运行PM2和Node.js

    在Stream,我们构建了许多应用程序来展示我们的服务所提供的出色功能。对于几乎所有的应用程序,我们都将它们放在一个云服务器上—通常是DigitalOcean或AWS EC2。

    虽然维护代码库和维持它的相关性是有困难的,但我们发现,在维护应用程序时,最具挑战性的是保持它的活动和运行。

    此外,由于Node.js是大多数后端API的核心语言,因此很难扩展单个线程进程;这就是PM2发挥作用的地方,也是我们如此喜欢使用它的原因。

    现在有很多流程管理器,最著名的是Forever、StrongLoop的流程管理器和good ol ' SystemD。还有PM2,下载量超过6000万次,GitHub之星达到2.5万颗(而且还在不断上升!)我们喜欢PM2,因为简单地说,它易于使用,并且可以完美的管理生产环境。

    PM2是什么呢?

    PM2是一个经过测试的,Node.js应用程序的生产运行时和进程管理器。它还配备了内置的负载均衡器,使扩展应用程序更加容易。最重要的是,它可以在Linux、Windows和MacOS上工作。

    我们使用配置文件(process.json),就可以指定要运行哪些进程以及要扩展到多少进程。启动PM2时,可以指定process.json文件,而PM2负责其余的事务。所有这些都意味着PM2允许我们永远保持Node.js应用程序的活跃,而且还是0秒停机重载,维护升级的时候不需要停机。

    安装PM2 
    安装PM2简直就是小菜一碟。首先,您需要确保process.json文件已经准备好进入代码,这样我们就可以开始这个过程了。如果您在MacOS上,是非常简单的,用yarn安装PM2就可以了。如果您在Linux、Windows或使用Docker容器(是的,它也支持Docker),请按照这里的说明操作。如果您想知道它应该是什么样子的话,下面是一个用于Winds的process_prod.json文件的示例,这是我们的开源rss和播客应用程序。

    {
      "apps": [
        {
          "name": "api",
          "cwd": "api/dist",
          "script": "server.js",
          "watch": false
        },
        {
          "name": "conductor",
          "cwd": "api/dist/workers",
          "script": "conductor.js",
          "watch": false
        },
        {
          "name": "rss-worker",
          "cwd": "api/dist/workers",
          "script": "rss.js",
          "instances": 2,
          "exec_mode": "cluster",
          "watch": false
        },
        {
          "name": "podcast-worker",
          "cwd": "api/dist/workers",
          "script": "podcast.js",
          "instances": 2,
          "exec_mode": "cluster",
          "watch": false
        },
        {
          "name": "og-worker",
          "cwd": "api/dist/workers",
          "script": "og.js",
          "instances": 2,
          "exec_mode": "cluster",
          "watch": false
        }
      ]
    }
    

    正如您所见,我们正在运行多个进程,而PM2在没有任何问题的情况下处理它们,使用Node.js集群API自动生成多个进程。

    提示和技巧 
    对于任何应用程序(我们这里是进程管理器),最好从以前使用过它的人那里了解一些技巧。

    自动重启

    一旦启动,您的应用程序将永远保持活动状态,在崩溃和机器重新启动后自动重新启动-所有这些都只需要一个简单的命令:pm2 startup

    进程管理


    无论运行多少应用程序,PM2都有一套指令,是我们可以分别管理它们各自的状态。下面是一些我们常用的一些的指令(无先后顺序):
    pm2 start process_prod.json-通过进程json文件启动进程
    pm2 ls-显示所有应用程序的列表
    pm2 stop <app>-停止一个特定的应用程序
    pm2 start <app>-启动一个特定的应用程序
    pm2 <app> scale N-将您指定的应用程序缩放到N个实例(可用于扩大或缩小)
    pm2 kill-杀死所有正在运行的应用程序
    pm2 restart-重新启动所有正在运行的应用程序
    pm2 reload-重新加载应用程序配置(当您修改应用程序的环境变量时,这很方便)

    进程管理

    运行指令pm2 monit将返回关于应用程序健康状况的丰富数据集。例如,您将看到CPU利用率、内存使用量、请求/分钟等等!

    广州VI设计公司https://www.houdianzi.com

    日志管理

    PM2有内置的日志管理。它汇聚里来自所有应用程序的日志数据,并将其写入单个源以供查看。您甚至可以实时跟踪日志,以查看应用程序的幕后情况。来自PM2的日志管理也伴随着日志循环,这一点非常重要,尤其是当应用程序频繁地输出冗长的日志时。

    我经常使用三个命令,你也应该这样做:
    pm2 logs—从所有运行的应用程序输出日志
    pm2 logs app—仅从应用程序输出日志
    pm2 flush—刷新所有日志数据,释放磁盘空间
    记住,要做的最重要的事情是启用日志循环。这样做将把一个巨大的日志文件分割成许多更小的文件,这些文件对于PM2来说更便于管理。为此,运行以下指令:
    pm2 install pm2-logrotate
    有关日志管理的更多信息可以在这里找到。

    如果您发现您的服务器上经常充满日志,请考虑使用集中式日志服务,如Loggly、Papertrail或ELK。

    最佳做法 
    总的来说,我喜欢遵循应用程序The Twelve-Factor App中列出的惯例。它们将帮助您充分利用PM2。如果你还没有读过这份宣言,它可以归结为以下12条规则:

    1.在修订控制中监测一个代码基,有效利用多个代码基 
    2.显式声明和隔离依赖项 
    3.在环境中存储配置 
    4.将支持服务视为附加资源 
    5.严格分开构建和运行阶段 
    6.将应用程序作为一个或多个无状态进程执行 
    7.通过端口绑定导出服务 
    8.通过流程模型向外扩展 
    9.以快速启动和优雅的关机最大化鲁棒性 
    10.保持开发、分期和生产尽可能相似 
    11·将日志视为事件流 
    12· 一次性运行管理任务

    如果您遵循上面的规则,您将能够有效地使用PM2扩展任何应用程序,并且几乎没有错误。今天的分享就到这里,希望本文能帮助到您!

  • 相关阅读:
    leetcode165
    leetcode63
    leetcode92
    leetcode86
    捣鼓Haskell
    递归操作链表
    treap(堆树)
    贪心策略 — 分数背包
    LeetCode.21
    LeetCode.94
  • 原文地址:https://www.cnblogs.com/qianxiaox/p/14035569.html
Copyright © 2011-2022 走看看