接下来,就让我们看看forever能不能实现目标。
一、forever介绍
forever是一个简单的命令式nodejs的守护进程,能够启动,停止,重启App应用。forever完全基于命令行操作,在forever进程之下,创建node的子进程,通过monitor监控node子进程的运行情况,一旦文件更新,或者进程挂掉,forever会自动重启node服务器,确保应用正常运行。
二、 forever安装
全局安装forever
~ D:\workspace\javascript>npm install -g forever D:\toolkit\nodejs\forever -> D:\toolkit\nodejs\node_modules\forever\bin\forever D:\toolkit\nodejs\foreverd -> D:\toolkit\nodejs\node_modules\forever\bin\foreverd
~ D:\workspace\javascript>forever -h help: usage: forever [action] [options] SCRIPT [script-options] help: help: Monitors the script specified in the current process or as a daemon help: help: actions: help: start Start SCRIPT as a daemon help: stop Stop the daemon SCRIPT help: stopall Stop all running forever scripts help: restart Restart the daemon SCRIPT help: restartall Restart all running forever scripts help: list List all running forever scripts help: config Lists all forever user configuration help: set <key> <val> Sets the specified forever config <key> help: clear <key> Clears the specified forever config <key> help: logs Lists log files for all forever processes help: logs <script|index> Tails the logs for <script|index> help: columns add <col> Adds the specified column to the output in `forever list` help: columns rm <col> Removed the specified column from the output in `forever list` help: columns set <cols> Set all columns for the output in `forever list` help: cleanlogs [CAREFUL] Deletes all historical forever log files help: help: options: help: -m MAX Only run the specified script MAX times help: -l LOGFILE Logs the forever output to LOGFILE help: -o OUTFILE Logs stdout from child script to OUTFILE help: -e ERRFILE Logs stderr from child script to ERRFILE help: -p PATH Base path for all forever related files (pid files, etc.) help: -c COMMAND COMMAND to execute (defaults to node) help: -a, --append Append logs help: -f, --fifo Stream logs to stdout help: -n, --number Number of log lines to print help: --pidFile The pid file help: --sourceDir The source directory for which SCRIPT is relative to help: --minUptime Minimum uptime (millis) for a script to not be considered "spinning" help: --spinSleepTime Time to wait (millis) between launches of a spinning script. help: --colors --no-colors will disable output coloring help: --plain alias of --no-colors help: -d, --debug Forces forever to log debug output help: -v, --verbose Turns on the verbose messages from Forever help: -s, --silent Run the child script silencing stdout and stderr help: -w, --watch Watch for file changes help: --watchDirectory Top-level directory to watch from help: --watchIgnore To ignore pattern when watch is enabled (multiple option is allowed) help: -h, --help You're staring at it help: help: [Long Running Process] help: The forever process will continue to run outputting log messages to the console. help: ex. forever -o out.log -e err.log my-script.js help: help: [Daemon] help: The forever process will run as a daemon which will make the target process start help: in the background. This is extremely useful for remote starting simple node.js scripts help: without using nohup. It is recommended to run start with -o -l, & -e. help: ex. forever start -l forever.log -o out.log -e err.log my-daemon.js help: forever stop my-daemon.js help:
我们看到forever支持的命令和配置项确实不少,应该是偏命令行的管理工具。
三、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历史日志
-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: 命令行帮助信息
四、forever服务器管理
创建一个web项目(express3+ejs),使用forever管理服务器。
安装express3
~ D:\workspace\javascript>express -e nodejs-forever ~ D:\workspace\javascript>cd nodejs-forever && npm install
~ D:\workspace\javascript\nodejs-forever>forever start app.js warn: --minUptime not set. Defaulting to: 1000ms warn: --spinSleepTime not set. Your script will exit if it does not stay up for at least 1000ms info: Forever processing file: app.js
打开浏览器: http://localhost:3000,可以看到web界面
在win下面查看forever状态
~ D:\workspace\javascript\nodejs-forever>forever list info: No forever processes running~ D:\workspace\javascript\nodejs-forever>forever stop app.js error: Forever cannot find process with index: app.js
五、forever在Ubuntu进行服务器管理
Linux的系统环境
Linux: Ubuntu 12.04.2 64bit Server
Node: v0.11.2
Npm: 1.2.21
初始化项目:安装命令不解释了
~ cd /home/conan/nodejs ~ express -e nodejs-forever ~ cd nodejs-forever && npm install ~ sudo npm install forever -g
~ forever start app.js warn: --minUptime not set. Defaulting to: 1000ms warn: --spinSleepTime not set. Your script will exit if it does not stay up for at least 1000ms info: Forever processing file: app.js
~ forever list info: Forever processes running data: uid command script forever pid logfile uptime data: [0] L2tY /usr/local/bin/node app.js 18276 18279 /home/conan/.forever/L2tY.log 0:0:0:37.792# 系统进程 ~ ps -aux|grep node Warning: bad ps syntax, perhaps a bogus '-'? See http://procps.sf.net/faq.html conan 18296 0.5 1.1 597696 23776 ? Ssl 15:48 0:00 /usr/local/bin/node /usr/local/lib/node_modules/forever/bin/monitor app.js conan 18299 0.4 0.8 630340 18392 ? Sl 15:48 0:00 /usr/local/bin/node /home/conan/nodejs/nodejs-forever/app.js
# 端口占用 ~ netstat -nltp|grep node tcp 0 0 0.0.0.0:3000 0.0.0.0:* LISTEN 18299/node
停止服务器
~ forever stop app.js info: Forever stopped process: data: uid command script forever pid logfile uptime [0] L2tY /usr/local/bin/node app.js 18276 18279 /home/conan/.forever/L2tY.log 0:0:0:45.621
我们看到在Linux Ubuntu环境中是正常的。
六、模拟服务器宕机
两种测试方案:
1. 用Linux命令,直接杀死node进程
2. 在应用中,模拟异常退出
1). 用Linux命令,直接杀死node进程
# 查看node进程,PID=18299 ~ ps -aux|grep nodeconan 18296 0.0 1.1 597696 23776 ? Ssl 15:48 0:00 /usr/local/bin/node /usr/local/lib/node_modules/forever/bin/monitor app.js conan 18299 0.0 0.8 630340 18392 ? Sl 15:48 0:00 /usr/local/bin/node /home/conan/nodejs/nodejs-forever/app.js conan 18315 0.0 0.0 13584 956 pts/5 R+ 15:52 0:00 grep --color=auto node
# 杀死PID=19299 ~ kill -9 18299
# 再看node进程,node自动重启,新的PID=18324 ~ ps -aux|grep node
conan 18296 0.0 1.1 597696 23916 ? Ssl 15:48 0:00 /usr/local/bin/node /usr/local/lib/node_modules/forever/bin/monitor app.js conan 18316 2.6 0.8 630340 18412 ? Sl 15:52 0:00 /usr/local/bin/node /home/conan/nodejs/nodejs-forever/app.js conan 18324 0.0 0.0 13584 956 pts/5 R+ 15:52 0:00 grep --color=auto node
杀死forever的monitor
~ kill -9 18296 ~ ps -aux|grep nodeconan 18316 0.0 0.9 630340 18644 ? Sl 15:52 0:00 /usr/local/bin/node /home/conan/nodejs/nodejs-forever/app.js conan 18333 0.0 0.0 13584 952 pts/5 S+ 15:57 0:00 grep --color=auto node
# 再杀死node进程 ~ kill -9 18316 ~ ps -aux|grep node
conan 18336 0.0 0.0 13584 956 pts/5 S+ 15:58 0:00 grep --color=auto node
2). 在应用中,模拟异常退出
修改文件:app.js
~ vi app.js//.. http.createServer(app).listen(app.get('port'), function(){ console.log(new Date()); console.log('Express server listening on port ' + app.get('port')); });
setTimeout(function(){ console.log(new Date()); throw new Error('App is error from inner!'); },10*1000);
~ node app.js Thu Sep 26 2013 16:08:44 GMT+0800 (CST) Express server listening on port 3000 Thu Sep 26 2013 16:08:54 GMT+0800 (CST)/home/conan/nodejs/nodejs-forever/app.js:41 throw new Error('App is error from inner!'); ^ Error: App is error from inner! at null._onTimeout (/home/conan/nodejs/nodejs-forever/app.js:41:9) at Timer.listOnTimeout [as ontimeout] (timers.js:110:15)
通过forever命令启动
~ mkdir logs ~ chmod 777 -R logs ~ forever -p . -l ./logs/access.log -e ./logs/error.log start app.js# 检查错误日志 ~ cat logs/access.log ls Thu Sep 26 2013 16:15:02 GMT+0800 (CST) Express server listening on port 3000 Thu Sep 26 2013 16:15:12 GMT+0800 (CST)
/home/conan/nodejs/nodejs-forever/app.js:41 throw new Error('App is error from inner!'); ^ Error: App is error from inner! at null._onTimeout (/home/conan/nodejs/nodejs-forever/app.js:41:9) at Timer.listOnTimeout [as ontimeout] (timers.js:110:15) error: Forever detected script exited with code: 8 error: Forever restarting script for 1 time Thu Sep 26 2013 16:15:13 GMT+0800 (CST) Express server listening on port 3000 Thu Sep 26 2013 16:15:23 GMT+0800 (CST)
/home/conan/nodejs/nodejs-forever/app.js:41 throw new Error('App is error from inner!'); ^ Error: App is error from inner! at null._onTimeout (/home/conan/nodejs/nodejs-forever/app.js:41:9) at Timer.listOnTimeout [as ontimeout] (timers.js:110:15) error: Forever detected script exited with code: 8 error: Forever restarting script for 2 time Thu Sep 26 2013 16:15:23 GMT+0800 (CST) Express server listening on port 3000 Thu Sep 26 2013 16:15:33 GMT+0800 (CST)
/home/conan/nodejs/nodejs-forever/app.js:41 throw new Error('App is error from inner!'); ^ Error: App is error from inner! at null._onTimeout (/home/conan/nodejs/nodejs-forever/app.js:41:9) at Timer.listOnTimeout [as ontimeout] (timers.js:110:15) error: Forever detected script exited with code: 8 error: Forever restarting script for 3 time Thu Sep 26 2013 16:15:33 GMT+0800 (CST) Express server listening on port 3000 Thu Sep 26 2013 16:15:43 GMT+0800 (CST)
/home/conan/nodejs/nodejs-forever/app.js:41 throw new Error('App is error from inner!'); ^ Error: App is error from inner! at null._onTimeout (/home/conan/nodejs/nodejs-forever/app.js:41:9) at Timer.listOnTimeout [as ontimeout] (timers.js:110:15) error: Forever detected script exited with code: 8 error: Forever restarting script for 4 time
通过list我们手动刷新几次也可以看到pid是变的。
~ forever list info: Forever processes running data: uid command script forever pid logfile uptime data: [0] SmtT /usr/local/bin/node app.js 18444 18579 logs/access.log 0:0:0:7.211~ forever list info: Forever processes running data: uid command script forever pid logfile uptime data: [0] SmtT /usr/local/bin/node app.js 18444 18579 logs/access.log 0:0:0:8.921
~ forever list info: Forever processes running data: uid command script forever pid logfile uptime data: [0] SmtT /usr/local/bin/node app.js 18444 18604 logs/access.log 0:0:0:0.177
~ forever list info: Forever processes running data: uid command script forever pid logfile uptime data: [0] SmtT /usr/local/bin/node app.js 18444 18604 logs/access.log 0:0:0:2.206
比起upstart管理,省略了配置脚本的步骤(/etc/init/nodejs-xx.conf)。其他的功能,还要更近一步的使用才知道。
七、开发环境和生产环境的启动配置
开发环境
~ cd /home/conan/nodejs/nodejs-forever/ ~ forever -p . -l ./logs/access.log -e ./logs/error.log -a -w start app.js
~ export LOG=/var/log/nodejs/project ~ export PID=/var/log/nodejs/project/forever.pid ~ export APP_PATH=/home/conan/nodejs/nodejs-forever ~ export APP=$APP_PATH/app.js~ forever -p $APP_PATH -l $LOG/access.log -e $LOG/error.log -o $LOG/out.log -a --pidFile $PID start $APP
本文向大家介绍详解Nodejs的timers模块,包括了详解Nodejs的timers模块的使用技巧和注意事项,需要的朋友参考一下 本模块,属于来模拟一些浏览器自带方法的模块,比如setTimeout,clearTimeout等方法,之所以会有该模块,在我看来,也是为了能让前端工程师使用起来,更简单,使用一个单独的模块,来把浏览器上的功能来模拟出来,那么就可以直接减少学习的成本,这样就可以花更少的
本文向大家介绍NodeJs中的VM模块详解,包括了NodeJs中的VM模块详解的使用技巧和注意事项,需要的朋友参考一下 什么是VM? VM模块是NodeJS里面的核心模块,支撑了require方法和NodeJS的运行机制,我们有些时候可能也要用到VM模板来做一些特殊的事情。 通过VM,JS可以被编译后立即执行或者编译保存下来稍后执行(JavaScript code can be compiled
本文向大家介绍Python使用进程Process模块管理资源,包括了Python使用进程Process模块管理资源的使用技巧和注意事项,需要的朋友参考一下 进程Process是对各种资源管理的集合,包含对各种资源的调用、内存的管理、网络接口的调用;一个进程Process可以包含多个子进程,启动一个进程的时候会自动创建一个线程,进程里的第一个线程就是主线程(即python __name__ == ‘
一、简介 V9系统可以自定义开发模块(详情请参考V9二次开发指南)。可对模块的安装,卸载等管理。 二、功能演示 1.安装 将已经创建好的模块放在指定位置,运行后台后,在“模块管理”处会找到你创建的模块。如下图: 如模块配置和代码无问题,系统将提示安装成功,否则提示错误。安装成功后你就可以使用该模块了(详情请参考V9二次开发指南)。 2.卸载 安装后的模块如果你不需要,可进行卸载。如下图:
一、简介 “模块管理"用于用户管理系统自带或者用户自定义开发模块的设置以及配置的等。这里且说系统自带。 二、功能演示 表单向导 广告 新闻心情 短消息 投票 友情链接 评论 公告 模块管理 全站搜素 数据源 点评模块 物流模块 在线充值 短信平台 外部数据导入 手机门户
本文向大家介绍详解nodejs 文本操作模块-fs模块(五),包括了详解nodejs 文本操作模块-fs模块(五)的使用技巧和注意事项,需要的朋友参考一下 fs模块是一个比较庞大的模块,在前面也介绍了该模块中最核心的一点东西,虽然核心的这点东西,在整个fs模块中占据的比例比较小,但是如果只是我们平常使用的话,基本已经够用了,其他的一些方法,属于能力提升时需要学习的的内容了,所以在后面就不再继续了,