• pm2常用的命令用法介绍


    $ pm2 start app.js              # 启动app.js应用程序
    $ pm2 startup                    # 创建开机自启动命令
    $ pm2 save                       # 保存当前应用列表
    

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

    PM2 (github上的源码)是开源的基于Nodejs的进程管理器,包括守护进程,监控,日志的一整套完整的功能,基本是Nodejs应用程序不二的守护进程选择,事实上它并不仅仅可以启动Nodejs的程序,只要是一般的脚本的程序它同样可以胜任。

    以下是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是node进程管理工具,可以利用它来简化很多node应用管理的繁琐任务,如性能监控、自动重启、负载均衡等,而且使用非常简单。

    下面就对PM2进行入门性的介绍,基本涵盖了PM2的常用的功能和配置。

    安装
    全局安装,简直不能更简单。

    ​npm install -g pm2
    目录介绍
    pm2安装好后,会自动创建下面目录。看文件名基本就知道干嘛的了,就不翻译了。

    $HOME/.pm2 will contain all PM2 related files
    $HOME/.pm2/logs will contain all applications logs
    $HOME/.pm2/pids will contain all applications pids
    $HOME/.pm2/pm2.log PM2 logs
    $HOME/.pm2/pm2.pid PM2 pid
    $HOME/.pm2/rpc.sock Socket file for remote commands
    $HOME/.pm2/pub.sock Socket file for publishable events
    $HOME/.pm2/conf.js PM2 Configuration
    

    入门教程
    挑我们最爱的express应用来举例。一般我们都是通过npm start启动应用,其实就是调用node ./bin/www。那么,换成pm2就是

    注意,这里用了--watch参数,意味着当你的express应用代码发生变化时,pm2会帮你重启服务,多贴心。

    pm2 start ./bin/www --watch
    入门太简单了,没什么好讲的。直接上官方文档:http://pm2.keymetrics.io/docs/usage/quick-start

    常用命令
    启动
    参数说明:

    • --watch:监听应用目录的变化,一旦发生变化,自动重启。如果要精确监听、不见听的目录,最好通过配置文件。
    • -i --instances:启用多少个实例,可用于负载均衡。如果-i 0或者-i max,则根据当前机器核数确定实例数目。
    • --ignore-watch:排除监听的目录/文件,可以是特定的文件名,也可以是正则。比如--ignore-watch="test node_modules "some scripts""
    • -n --name:应用的名称。查看应用信息的时候可以用到。
    • -o --output :标准输出日志文件的路径。
    • -e --error :错误输出日志文件的路径。
    • --interpreter :the interpreter pm2 should use for executing app (bash, python...)。比如你用的coffee script来编写应用。

    完整命令行参数列表:地址

    pm2 start app.js --watch -i 2
    重启
    pm2 restart app.js
    停止
    停止特定的应用。可以先通过pm2 list获取应用的名字(--name指定的)或者进程id。

    pm2 stop app_name|app_id
    如果要停止所有应用,可以

    pm2 stop all
    删除
    类似pm2 stop,如下

    pm2 stop app_name|app_id pm2 stop all
    查看进程状态
    pm2 list
    查看某个进程的信息
    [root@iZ94wb7tioqZ pids]# pm2 describe 0 Describing process with id 0 - name oc-server

    [root@iZ94wb7tioqZ pids]# pm2 describe 0 Describing process with id 0 - name oc-server
    ┌───────────────────┬──────────────────────────────────────────────────────────────┐
    │ status            │ online                                                       │
    │ name              │ oc-server                                                    │
    │ id                │ 0 │
    │ path              │ /data/file/qiquan/over_the_counter/server/bin/www            │
    │ args              │                                                              │
    │ exec cwd          │ /data/file/qiquan/over_the_counter/server                    │
    │ error log path    │ /data/file/qiquan/over_the_counter/server/logs/app-err-0.log │
    │ out log path      │ /data/file/qiquan/over_the_counter/server/logs/app-out-0.log │
    │ pid path          │ /root/.pm2/pids/oc-server-0.pid                              │
    │ mode              │ fork_mode                                                    │
    │ node v8 arguments │                                                              │
    │ watch & reload    │                                                             │
    │ interpreter       │ node                                                         │
    │ restarts          │ 293 │
    │ unstable restarts │ 0 │
    │ uptime            │ 87m │
    │ created at        │ 2016-08-26T08:13:43.705Z                                     │
    └───────────────────┴──────────────────────────────────────────────────────────────┘  
    

    太多了,抄不过来了

  • 相关阅读:
    Android-View动画
    Android-RemoteView-桌面小部件
    系统的Drawable(四)-LayerListDrawable
    Android-Drawable(三)
    系统的Drawable(二)-Selector
    系统的Drawable(一)
    Android View事件分发-从源码分析
    打游戏要存进度-备忘录模式
    Java 内部类.md
    docker 常用 命令
  • 原文地址:https://www.cnblogs.com/faberbeta/p/13915600.html
Copyright © 2020-2023  润新知