• 首页
  • nodejs
  • forever node.js web应用中不可或缺的伟大模块

forever node.js web应用中不可或缺的伟大模块

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


能做什么?

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


如何使用?

forever 必须在全局环境下安装

sudo npm install forever -g


查看帮助信息

zhangzhi@moke:~$ 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


比较常用到的命令上面都简单列出来了.还有一些参数需要搭配命令使用,比如制定输出日志和错误日志路径等.


常见的参数配置

-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: 命令行帮助信息


******end*****

回到顶部