node错误处理与日志记录的实现


Posted in Javascript onDecember 24, 2018

node项目中的错误处理

node中Error对象的使用

使用captureStackTrace方法加入自带的错误信息

// Error对象自带的属性
Error.captureStackTrace

// 如何使用captureStackTrace
var obj = {
  message: 'something is wrong'
}

Error.captureStackTrace(obj)

throw obj  // 此时会抛出obj对象的message内信息

使用try catch捕获错误

直接把代码写在try catch中即可捕获错误信息

try{
  throw new Error('oh no')
}catch(e){
  console.log(e)
}

在异步代码中,直接try catch是无法捕获错误信息的,可以使用如下方法

function foo(params, cb){
  const error = new Error('something is wrong')
  if(error) cb(error)
}

以上使用callback方式来做错误处理比较容易麻烦,容易出错,现在node已经支持async await所以尽量使用它们准没错

async function foo(){
  try{
    await bar()
  }catch(e){
    console.log(e)
  }
}

async function bar(){
  throw new Error('async function got wrong)
}

foo()

基本错误类型

在项目会有多个地方对错误信息进行处理,所以先写一个基本错误类型,方便使用

// 基本错误类型
class HttpBaseError extends Error {
 constructor(httpStatusCode, httpMsg, errCode, msg) {
  super(`HTTP ERROR: ${msg}`);
  this.httpStatusCode = httpStatusCode;
  this.httpMsg = httpMsg;
  this.errCode = errCode;
 }
}

try {
// 直接抛出定义好的错误即可
 throw new HttpBaseError(404, '资源不存在', 10000, 'resouse is not found');
} catch (e) {
 console.log(e.message);
 console.log(e.httpStatusCode);
 console.log(e.httpMsg);
 console.log(e.errCode);
}

特定错误类型

除了基本类型,不同情况下会有不同错误信息,需要用一个特定的错误类型来处理特定的错误信息

// 一个参数错误类型
const ERROR_CODE = 40000  // 错误码
class HttpRequestParamError extends HttpBaseError {
  constructor(paramName, desc, msg) {
    super(200, desc, ERROR_CODE, `${paramName} wrong: ${msg}`)
  }
}

这样,在参数错误的地方就能非常方便的调用这个错误类型来返回错误

抛错的逻辑

错误处理中,model,controller中的错误,有些是不能直接返回给用户的,应该只返回给model或controller的调用者。

使用错误处理

正常接口,controller,model的错误,使用设定好的错误类型进行处理,例如前面写的HttpRequestParamError,在所有所有路由的最后,需要使用一个error handler来对所有的错误进行集中处理

// error handler
function handler(options) {
  return function (err, req, res, next) {
    if (err instanceof HttpRequestParamError) {  // 这里对不同的错误做不同的处理
      console.log('http request error')
      res.statusCode = err.httpStatusCode
      res.json({
        code: err.errCode,
        msg: err.httpMsg
      })
    } else {
      // 设定之外的错误,把管理权向外移交
      next(err)
    }
  }
}

除了可预知的错误,还有未知的类型的错误,此时需要一个unknow error handler进行剩余错误的处理

function unKnowErrorHandler(options) {
  return function (err, req, res, next) {
    console.log(err)
    res.json({
      code: 99999,
      msg: 'unKnow error'
    })
  }
}

node中的日志

平时使用console来debug是没有问题的,但是在线上环境,我们并不能有效的看到console,使用日志系统可以更好的方便线上的debug,记录信息等

winston的使用

winston是node中常用的日志插件

const winston = require('winston')

const logger = winston.createLogger({
  transports: [
    new winston.transports.Console(),
    new winston.transports.File({
      name: 'info_logger',  // log名称
      filename: 'logs/info.log',  // 日志记录文件地址
      level: 'info' // 设置log的类型
    }),
    // 第二个logger,记录error级别的log
    new winston.transports.File({
      name: 'error_logger',
      filename: 'logs/error.log',
      level: 'error'
    })
  ]
});

// error级别比info要高,error.log文件只会记录error日志
logger.error('first error log with winston')
// info文件内会记录info级别的log和比info级别高的log,比如error
logger.info('first info log with winston')

日志滚动(log rotation)

在产生大量数据的应用当中,日志的输出是大量的,这是就需要对日志进行拆分处理,例如按照每天的频率来分别记录日志。

winston并不自带log rotation,需要引入winston-daily-rotate-file库

const {
  createLogger,
  format,
  transports
} = require('winston');
const {
  combine,
  timestamp,
  label,
  prettyPrint
} = format;
require('winston-daily-rotate-file')


var transport = new(transports.DailyRotateFile)({
  filename: './logs/app-%DATE%.log',
  datePattern: 'YYYY-MM-DD-HH',
  maxSize: '20m',
  maxFiles: '14d',
  format: combine(
    label({
      label: 'right meow!'
    }),
    timestamp(),
    prettyPrint()
  ),
});
transport.on('rotate', function (oldFilename, newFilename) {});

var logger = createLogger({
  transports: [
    transport
  ]
});

logger.info('Hello World!');

运行日志文件,此时在logs目录下就生成了今天的日志

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery键盘事件介绍
Jan 31 Javascript
动态创建script在IE中缓存js文件时导致编码的解决方法
May 04 Javascript
JavaScript AJAX之惰性载入函数
Aug 27 Javascript
jQuery插件Tooltipster实现漂亮的工具提示
Apr 12 Javascript
jquery 构造函数在表单提交过程中修改数据
May 25 Javascript
js window对象属性和方法相关资料整理
Nov 11 Javascript
设计模式中的组合模式在JavaScript程序构建中的使用
May 18 Javascript
客户端验证用户名和密码的方法详解
Jun 16 Javascript
微信小程序 视图层(xx.xml)和逻辑层(xx.js)详细介绍
Oct 13 Javascript
angular中不同的组件间传值与通信的方法
Nov 04 Javascript
vue对storejs获取的数据进行处理时遇到的几种问题小结
Mar 20 Javascript
react-native滑动吸顶效果的实现过程
Jun 03 Javascript
详解如何在vscode里面调试js和node.js的方法步骤
Dec 24 #Javascript
@angular前端项目代码优化之构建Api Tree的方法
Dec 24 #Javascript
微信小程序获取用户openid的实现
Dec 24 #Javascript
vue-router启用history模式下的开发及非根目录部署方法
Dec 23 #Javascript
小程序实现人脸识别功能(百度ai)
Dec 23 #Javascript
优雅的elementUI table单元格可编辑实现方法详解
Dec 23 #Javascript
基于webpack4.X从零搭建React脚手架的方法步骤
Dec 23 #Javascript
You might like
PHP iconv 函数转gb2312的bug解决方法
2009/10/11 PHP
PHP+ajax 无刷新删除数据
2010/02/20 PHP
PHP使用PDO操作数据库的乱码问题解决方法
2016/04/08 PHP
thinkPHP框架通过Redis实现增删改查操作的方法详解
2019/05/13 PHP
laravel框架上传图片实现实时预览功能
2019/10/14 PHP
javascript 函数式编程
2007/08/16 Javascript
JavaScript中Math对象方法使用概述
2014/01/02 Javascript
利用浏览器全屏api实现js全屏
2014/01/16 Javascript
在HTML代码中使用JavaScript代码的例子
2014/10/16 Javascript
JS基于面向对象实现的放烟花效果
2015/05/07 Javascript
jQuery文字横向滚动效果的实现代码
2016/05/31 Javascript
jquery设置css样式的多种方法(总结)
2017/02/21 Javascript
在 Angular 中实现搜索关键字高亮示例
2017/03/21 Javascript
js实现华丽的九九乘法表效果
2017/03/29 Javascript
详解angular中的作用域及继承
2017/05/31 Javascript
详解Vue整合axios的实例代码
2017/06/21 Javascript
详解vuejs之v-for列表渲染
2017/06/22 Javascript
React服务端渲染(总结)
2017/07/01 Javascript
基于jQuery对象和DOM对象和字符串之间的转化实例
2017/08/08 jQuery
探究react-native 源码的图片缓存问题
2017/08/24 Javascript
Vue导出json数据到Excel电子表格的示例
2017/12/04 Javascript
Vue 实时监听窗口变化 windowresize的两种方法
2018/11/06 Javascript
Smartour 让网页导览变得更简单(推荐)
2019/07/19 Javascript
js实现炫酷光感效果
2020/09/05 Javascript
微信小程序实现音乐播放页面布局
2020/12/11 Javascript
pycharm运行程序时在Python console窗口中运行的方法
2018/12/03 Python
pycharm显示远程图片的实现
2019/11/04 Python
python Shapely使用指南详解
2020/02/18 Python
Selenium元素定位的30种方式(史上最全)
2020/05/11 Python
PyQt5结合matplotlib绘图的实现示例
2020/09/15 Python
为娇小女性量身打造:Petite Studio
2018/11/01 全球购物
美国第二大连锁药店:Rite Aid
2019/04/03 全球购物
架构师岗位职责
2013/11/18 职场文书
2014年幼儿园植树节活动方案
2014/03/02 职场文书
机关作风建设剖析材料
2014/10/11 职场文书
2015秋季开学演讲稿范文
2015/07/16 职场文书