pm2常用的命令用法介绍

PM2常用命令:pm2 是一个带有负载均衡功能的Node应用的进程管理器.当你要把你的独立代码利用全部的服务器上的所有CPU,并保证进程永远都活着,0秒的重载, PM2是完美的,下面我们来看pm2常用的命令用法介绍吧。


$ pm2 list                      # 列表 PM2 启动的所有的应用程序
$ pm2 show[app - name]          # 显示应用程序的所有信息

$ pm2 logs                       # 显示所有应用程序的日志
$ pm2 logs[app - name]           # 显示指定应用程序的日志

$ pm2 stop all                   # 停止所有的应用程序
$ pm2 stop 0                     # 停止 id为 0的指定应用程序

$ pm2 start all                  # 启动所有的应用程序
$ pm2 start 0                    # 启动 id为 0的指定应用程序

$ pm2 start app.js              # 启动app.js应用程序
$ pm2 start app.js--name = "api" # 启动应用程序并命名为 "api"

$ pm2 restart all               # 重启所有应用
$ pm2 restart all               # 重启  id为 0的指定应用程序

$ pm2 delete all                # 关闭并删除所有应用
$ pm2 delete 0                  # 删除指定应用 id 0


PM2更多命令简介


$ pm2 start app.js              # 启动app.js应用程序

$ pm2 start app.js - i 4         # cluster mode 模式启动4个app.js的应用实例     # 4个应用程序会自动进行负载均衡

$ pm2 start app.js--name = "api" # 启动应用程序并命名为 "api"

$ pm2 start app.js--watch      # 当文件变化时自动重启应用

$ pm2 start script.sh           # 启动 bash 脚本


$ pm2 list                      # 列表 PM2 启动的所有的应用程序

$ pm2 monit                     # 显示每个应用程序的CPU和内存占用情况

$ pm2 show[app - name]# 显示应用程序的所有信息


$ pm2 logs                      # 显示所有应用程序的日志

$ pm2 logs[app - name]# 显示指定应用程序的日志

$ pm2 flush


$ pm2 stop all                  # 停止所有的应用程序

$ pm2 stop 0                    # 停止 id为 0的指定应用程序

$ pm2 restart all               # 重启所有应用

$ pm2 reload all                # 重启 cluster mode下的所有应用

$ pm2 gracefulReload all        # Graceful reload all apps in cluster mode

$ pm2 delete all                # 关闭并删除所有应用

$ pm2 delete 0                  # 删除指定应用 id 0

$ pm2 scale api 10              # 把名字叫api的应用扩展到10个实例

$ pm2 reset[app - name]# 重置重启数量


$ pm2 startup                   # 创建开机自启动命令

$ pm2 save                      # 保存当前应用列表

$ pm2 resurrect                 # 重新加载保存的应用列表

$ pm2 update                    # Save processes, kill PM2 and restore processes

$ pm2 generate                  # Generate a sample json configuration file


$ pm2 deploy app.json prod setup    # Setup "prod" remote server

$ pm2 deploy app.json prod          # Update "prod" remote server

$ pm2 deploy app.json prod revert 2 # Revert "prod" remote server by 2


$ pm2 module: generate[name]# Generate sample module with name[name]

$ pm2 install pm2 - logrotate     # Install module(here a log rotation system)

$ pm2 uninstall pm2 - logrotate   # Uninstall module

$ pm2 publish                   # Increment version, git push and npm publish



PM2通过JSON配置文件微调每个进程的行为

PM2允许您通过JSON配置文件微调每个进程的行为,选项,环境变量和日志文件,从而为您的流程管理工作流提供支持。它对于基于微服务的应用程序特别有用:

{
    "apps": {
        "name": "wuwu",                             // 项目名          
        "script": "./bin/www",                      // 执行文件
        "cwd": "./",                                // 根目录
        "args": "",                                 // 传递给脚本的参数
        "interpreter": "",                          // 指定的脚本解释器
        "interpreter_args": "",                     // 传递给解释器的参数
        "watch": true,                              // 是否监听文件变动然后重启
        "ignore_watch": [                           // 不用监听的文件
            "node_modules",
            "logs"
        ],
        "exec_mode": "cluster_mode",                // 应用启动模式,支持fork和cluster模式
        "instances": 4,                             // 应用启动实例个数,仅在cluster模式有效 默认为fork;或者 max
        "max_memory_restart": '100M',                 // 最大内存限制数,超出自动重启;例如:"2G", "10M", "100K"
        "error_file": "./logs/app-err.log",         // 错误日志文件
        "out_file": "./logs/app-out.log",           // 正常日志文件
        "merge_logs": true,                         // 设置追加日志而不是新建日志
        "log_date_format": "YYYY-MM-DD HH:mm:ss",   // 指定日志文件的时间格式
        "min_uptime": "60s",                        // 应用运行少于时间被认为是异常启动
        "max_restarts": 30,                         // 最大异常重启次数,即小于min_uptime运行时间重启次数;
  		"cron_restart": "1 0 * * *",                // 定时启动,解决重启能解决的问题
        "autorestart": true,                        // 默认为true, 发生异常的情况下自动重启
        "cron_restart": "",                         // crontab时间格式重启应用,目前只支持cluster模式;
        "restart_delay": "60s"                      // 异常重启情况下,延时重启时间
        "env": {
           "NODE_ENV": "production",                // 环境参数,当前指定为生产环境 process.env.NODE_ENV
           "REMOTE_ADDR": "爱上大声地"               // process.env.REMOTE_ADDR
        },
        "env_dev": {
            "NODE_ENV": "development",              // 环境参数,当前指定为开发环境 pm2 start app.js --env_dev
            "REMOTE_ADDR": ""
        },
        "env_test": {                               // 环境参数,当前指定为测试环境 pm2 start app.js --env_test
            "NODE_ENV": "test",
            "REMOTE_ADDR": ""
        }
    }
}

参考链接:
pm2官网
pm2配置文件介绍
pm2日志分割

<think>好的,用户想了解如何使用PM2启动应用程序,特别是示例命令。首先,我需要回忆一下PM2的基本用法。根据引用中的资料,PM2是一个Node.js进程管理工具,可以后台运行应用,并且支持多种配置。 用户提到了启动命令,所以首先应该给出最基本的启动方式。比如,直接使用`pm2 start app.js`,这可能已经在引用中提到了。例如,引用[2]和[3]都提到启动应用程序的命令,其中引用[2]还提到使用`--name`参数来命名进程,这样方便管理。 接下来,用户可能需要更多定制化的启动选项。比如设置进程名称、使用集群模式、传递环境变量等。引用[3]提到了用fork模式启动并传递参数,所以需要说明`--`后面跟参数的方法。同时,集群模式在引用中没有直接提到,但PM2支持cluster模式,可以补充这一点。 另外,配置文件的使用也很重要,引用[4]提到了使用`ecosystem.config.js`文件来定义启动配置,这样可以保存复杂的设置,方便部署。需要说明如何生成配置文件并启动。 用户可能还关心如何查看已启动的进程,引用[1]中的`pm2 list`命令需要包含在内。此外,日志管理和重启策略也是PM2常用功能,应该简要提及。 需要确保所有命令示例正确,并正确引用相关的参考资料。例如,使用`--name`来自定义进程名来自引用[2],传递参数参考引用[3],配置文件的使用来自引用[4]。 最后,生成相关问题需要考虑用户可能的后续需求,比如进程监控、多环境配置、日志管理、集群模式等,这些问题可以帮助用户进一步了解PM2的高级功能。</think>### 如何使用PM2启动应用程序 PM2是Node.js应用进程管理工具,支持后台运行、负载均衡和自动重启等功能。以下是常用启动命令及说明: #### 1. **基础启动** 通过指定入口文件启动应用程序(默认以`fork`模式运行): ```bash pm2 start app.js ``` 若需自定义进程名称,使用`--name`参数: ```bash pm2 start app.js --name myapp # 进程名为"myapp"[^2] ``` #### 2. **传递参数** 启动时传递命令行参数,需在命令末尾添加`--`后接参数: ```bash pm2 start app.js -- -a 23 -p 8080 # 向app.js传递参数`-a 23 -p 8080`[^3] ``` #### 3. **集群模式** 启动多个实例以利用多核CPU(`-i`指定实例数): ```bash pm2 start app.js -i 4 # 启动4个实例(cluster模式) ``` #### 4. **配置文件启动** 通过`ecosystem.config.js`定义复杂配置(如环境变量、日志路径): ```bash pm2 init simple # 生成配置文件模板 pm2 start ecosystem.config.js # 根据配置文件启动[^4] ``` 配置文件示例: ```javascript module.exports = { apps: [{ name: "prod-server", script: "app.js", env: { NODE_ENV: "production", PORT: 3000 } }] } ``` #### 5. **其他常用操作** - 查看进程列表:`pm2 list`[^1] - 监视日志:`pm2 logs myapp` - 重启应用:`pm2 restart myapp` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值