使用forever管理nodejs应用

1. forever介绍

forever是一个简单的命令式nodejs的守护进程,能够启动,停止,重启App应用。forever完全基于命令行操作,在forever进程之下,创建node的子进程,通过monitor监控node子进程的运行情况,一旦文件更新,或者进程挂掉,forever会自动重启node服务器,确保应用正常运行。

代码如下:

A simple CLI tool for ensuring that a given script runs continuously (i.e. forever).

// 一个用来持续(或者说永远)运行一个给定脚本的简单的命令行工具

Github地址:https://github.com/nodejitsu/forever

2. forever安装

安装forever

代码如下:

// 记得加-g,forever要求安装到全局环境下

sudo npm install forever -g

3.forever使用说明

启动相关

代码如下:

// 1. 简单的启动

forever start app.js

// 2. 指定forever信息输出文件,当然,默认它会放到~/.forever/forever.log

forever start -l forever.log app.js

// 3. 指定app.js中的日志信息和错误日志输出文件,

// -o 就是console.log输出的信息,-e 就是console.error输出的信息

forever start -o out.log -e err.log app.js

// 4. 追加日志,forever默认是不能覆盖上次的启动日志,

// 所以如果第二次启动不加-a,则会不让运行

forever start -l forever.log -a app.js

// 5. 监听当前文件夹下的所有文件改动

forever start -w app.js

文件改动监听并自动重启

代码如下:

// 1. 监听当前文件夹下的所有文件改动(不太建议这样)

forever start -w app.js

显示所有运行的服务

代码如下:

forever list

停止操作

代码如下:

// 1. 停止所有运行的node App

forever stopall

// 2. 停止其中一个node App

forever stop app.js

// 当然还可以这样

// forever list 找到对应的id,然后:

forever stop [id]

重启操作

重启操作跟停止操作保持一致。

代码如下:

// 1. 启动所有

forever restartall

开发和线上建议配置

代码如下:

// 开发环境下

NODE_ENV=development forever start -l forever.log -e err.log -a app.js

// 线上环境下

NODE_ENV=production forever start -l ~/.forever/forever.log -e ~/.forever/err.log -w -a app.js

上面加上NODE_ENV为了让app.js辨认当前是什么环境用的。不加它可能就不知道哦?

一些注意点

有可能你需要使用unix下的crontab(定时任务)

这个时候需要注意配置好环境变量。

代码如下:

SHELL=/bin/sh

PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin

forever命令行的中文解释

子命令actions:

  • start:启动守护进程
  • stop:停止守护进程
  • stopall:停止所有的forever进程
  • restart:重启守护进程
  • restartall:重启所有的foever进程
  • list:列表显示forever进程
  • config:列出所有的用户配置项
  • set <key> <val>: 设置用户配置项
  • clear <key>: 清楚用户配置项
  • logs: 列出所有forever进程的日志
  • logs <script|index>: 显示最新的日志
  • columns add <col>: 自定义指标到forever list
  • columns rm <col>: 删除forever list的指标
  • columns set<cols>: 设置所有的指标到forever list
  • cleanlogs: 删除所有的forever历史日志

配置参数options:

  • -m MAX: 运行指定脚本的次数
  • -l LOGFILE: 输出日志到LOGFILE
  • -o OUTFILE: 输出控制台信息到OUTFILE
  • -e ERRFILE: 输出控制台错误在ERRFILE
  • -p PATH: 根目录
  • -c COMMAND: 执行命令,默认是node
  • -a, –append: 合并日志
  • -f, –fifo: 流式日志输出
  • -n, –number: 日志打印行数
  • –pidFile: pid文件
  • –sourceDir: 源代码目录
  • –minUptime: 最小spinn更新时间(ms)
  • –spinSleepTime: 两次spin间隔时间
  • –colors: 控制台输出着色
  • –plain: –no-colors的别名,控制台输出无色
  • -d, –debug: debug模式
  • -v, –verbose: 打印详细输出
  • -s, –silent: 不打印日志和错误信息
  • -w, –watch: 监控文件改变
  • –watchDirectory: 监控顶级目录
  • –watchIgnore: 通过模式匹配忽略监控
  • -h, –help: 命令行帮助信息

更多帮助请参考:粉丝日志 http://blog.fens.me/nodejs-server-forever/