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*****