之前一直考虑实现这么个流程:
- 获取用户更新数据的请求
- 更新缓存
- 返回结果
- 数据持久化
主要是不想让数据持久化这一步占用响应时间,实验的代码如下
app.get('/', function (req, res, next) {
res.status(200).jsonp({ data: "AAA" })
next()
}, function (req, res) {
setTimeout(function () {
console.log("Cached!");
}, 5000)
});
这里我们用了express的中间件,可以把数据处理的各个流程写到不同的function里面,根据需要组装。用POSTMAN测试一下,你会看到瞬间返回了“AAA”,然后过了5秒钟才在console打出了”Cached“,这基本就是我想要的结果。
然后继续实验,把
res.status(200).jsonp({ data: "AAA" })
改成
return res.status(200).jsonp({ data: "AAA" })
这次客户端正常返回,但是console没有打印出”Cached“,也就是说加了return之后直接结束了整个响应流程,后面的所有代码和中间件都不再执行了。
我们继续改造:
app.get('/', function (req, res, next) {
res.status(200).jsonp({ data: "AAA" })
next()
}, function (req, res) {
res.status(200).jsonp({ data: "BBB" })
setTimeout(function () {
console.log("Cached!");
}, 5000)
});
那如果我多次修改response对象会怎么样呢?
这次客户端也收到结果了,但是console却直接打印了Error:Cannot set header after they are sent.
由此我们可见res之后响应就直接发给客户端了。