Node.js web应用模块之forever

javascript 一统江湖的势头越来越猛,越来越重的前端,不得不实施前后端分离,angular.js 成功把前端javascript抽象成了一个复杂的MVC框架,注意,它是一个框架,可不是普普通通的插件,或者工具包.

另一位兄弟则是跳出浏览器宿主的限制,活跃在了服务器端,大名鼎鼎的 node.js

还有一位齐头并进的好哥们 mongodb ,它不仅让你使用熟悉的javascript范围数据库,而且还自己实现了javascript引擎.

可能创建 javascript 语言的大牛,看到今天js的发展事态,想必脊梁骨也是阵阵发凉.

我们好像扯远了,开题先痛痛快快意淫一把怎能善罢甘休,O(∩_∩)O~

由于node.js的异步IO,事件轮询等优点,越来越多的web服务在node.js 环境下运行起来,而且node.js 用几句简单的代码自己实现了一个服务器,牛掰大气上档次,可惜就是不能碰到错误,否则就挂.哈哈哈

可见再牛掰的 node.js ,运行在单进程上,一个错误还真有点受不了,所以我们需要一个持续的,稳定的,能重复启动,简单的命令控制,完善的log日志,甚至群集功能 (我不是在做梦吧^_^)

forever 的出现确实解决了部分我上面提到的需求,妈妈再也不用担心我的博客down机 ,(哎,其实博客经常挂,不过我妈确实也没有担心这个事)

官方的说明:

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

一个用来持续运行一个给定脚本的简单的命令行工具

Github地址:

https://github.com/nodejitsu/forever

https://github.com/foreverjs/forever

能做什么?

forever的用途就是帮我们更好的管理我们node App服务,本质上就是在forever进程之下,创建一个node app的子进程,保证你服务能持续运行,帮你自动重启服务而不需要手动重启.

如何使用?

forever 必须在全局环境下安装

sudo npm install forever -g

查看帮助信息

ikeepstudying@gideon:~$ forever --help

会列出很多很多……

你必须要掌握下面这几个

// 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
 
// 6. 显示所有运行的服务
 
forever list

//如下:
zhangzhi@moke:~/code/blog2014$ forever list
info:    Forever processes running
data:        uid  command             script   forever pid   id logfile                           uptime
data:    [0] H5f7 /usr/local/bin/node index.js 26400   26401    /Users/zhangzhi/.forever/H5f7.log 0:0:0:3.253
 
// 7. stop:停止守护进程
 
forever stop app.js

//或者

forever stop [uid]  
//[uid] 就是 forever list 对应查询到的启动服务里的 uid (比如上面的  H5f7 )

// 8. 停止所有守护进程

forever stopall

// 9. 重启某一个服务

forever restart app.js

// 10.重启所有服务

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

子命令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/

 

 

参考:http://yijiebuyi.com/blog/1a642c7b277bc213d3250e946073f045.html

本文:Node.js web应用模块之forever 

Leave a Reply