日志输出框架angular-logger和log4js-node

JavaScript026

日志输出框架angular-logger和log4js-node,第1张

angular-logger 是一个方便的实现前端日志输出的套件,并且可以在日志当中打印时间,日志来自的模块等等信息。

Chrome输出如下:

log4js-node 是我们Node Server端推荐采用的日志框架。可以配置文件输出,标准输出等等Appenders.

在application log里面也会有以下内容。

配置log4js与express框架集成

下载log4js包

~ npm install log4js

log4js@0.6.6 node_modules\log4js

├── dequeue@1.0.3

├── semver@1.1.4

├── async@0.1.15

└── readable-stream@1.0.2

修改app.js

~ vi app.js

var log4js = require('log4js')

log4js.configure({

appenders: [

{ type: 'console' }, //控制台输出

{

type: 'file', //文件输出

filename: 'logs/access.log',

maxLogSize: 1024,

backups:3,

category: 'normal'

}

]

})

var logger = log4js.getLogger('normal')

logger.setLevel('INFO')

...

//app.use(...)

//app.use(...)

app.use(log4js.connectLogger(logger, {level:log4js.levels.INFO}))

app.use(app.router)

我觉得我们程序首先功能应该是独立的,就是一个功能出异常了,不应该去影响另外

一个正常的功能,不应该将整个程序都崩溃掉,其次,即使是程序崩溃了,我们也应该有一个让程序自动启动,另外,应该去记录日志,方便我们跟踪问题。我觉得

主要可以从以下方面提高nodejs 稳定性:

1)保持良好的代码结构:

我们知道node是单线程,非阻塞io,默认就是异步,通过回调的方式处理后面的流程,如果嵌套的层次太多了,势必会引起代码逻辑结构的混乱,也不利于维护和升级,可以采用async这个异步流程控制模块,来理清我们的代码逻辑。

2)使用 process.on('uncaughtException', function(err){...})来处理未被捕捉的错误。

3)使用try~catch 来捕获异常:

这个只能解决一部分问题,不是万能的,在上面说到因为node是单线程,非阻塞io,默认就是异步,通过回调的方式处理后面的流程,try~catch

是不能捕获的callback 里面的error的错误的,怎么捕获到callback里面的错误呢 ? 可以采用domain模块

4)使用domain模块来处理程序的异常

先看看对domain的解释:domain是 EventEmitter类的一个子类。监听它的error事件来处理它捕捉到的错误。 它

提供了一种方式,即以一个单一的组的形式来处理多个不同的IO操作。如果任何一个注册到domain的事件触发器或回调触发了一个‘error’事件,或

者抛出一个错误,那么domain对象将会被通知到。而不是直接让这个错误的上下文从

`process.on('uncaughtException')'处理程序中丢失掉,也不会致使程序因为这个错误伴随着错误码立即退出。

5)使用log4js 模块记录日志

log4js 是一个非常强大的日志管理工具,在可以看看github这个项目: https://github.com/nomiddlename/log4js-node

6)使用forever 模块来管理nodejs

forever 是服务端管理nodejs 的一个模块,一个命令行工具,能够启动,停止app 应用。forever完全是基于命令行操作,在forever进程管理之下,创建node的子进程,通过monitor监控node子进程的运行情况,一旦文件更新,或者进程挂掉,forever会自动重启node服务器,确保应用正常运行。非常的好用.