请求时间过长进行提醒的中间件(了不起的nodejs chapter 8)

/**
request-time.js
*/
module.exports = function(opts) {
  var time = opts.time || 100;
  return function(req, res, next) {
    var timer = setTimeout(function() {
      console.log('%s %s taking too long', req.method, req.url);
    }, time);

    var end = res.end;
    res.end = function(chunk, encoding) {
      res.end = end;
      res.end(chunk, encoding);
      clearTimeout(timer);
    };
    next();
  };
};

/**
server.js
*/
var connect = require('connect'),
  time = require('./request-time');

var server = connect.createServer();

//server.use(connect.logger('dev'));
server.use(time({time: 500}));

server.use(function(req, res,next) {
  if ('/a' == req.url) {
    res.writeHead(200);
    res.end('Fast!');
  } else {
    next();
  }
});

server.use(function(req, res,next) {
  if ('/b' == req.url) {
    setTimeout(function() {
      res.writeHead(200);
      res.end('Slow');
    }, 1000);
  } else  {
    next();
  }
});

server.listen(3000);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值