V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
qwertyegg
V2EX  ›  Node.js

@awaitjs/express 怎么能够在 res.json()后继续完成一个长时间的任务

  •  
  •   qwertyegg · 2019-03-22 00:00:32 +08:00 · 3342 次点击
    这是一个创建于 2119 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我看到别人的提问里面

    var express = require('express');
    var app = express();
    
    app.get('/some/route', (req, res)=> {
      res.json({success: false, message: "End time must be AFTER start time"});
      console.log('Hi')
    });
    

    这个 console.log('Hi')会被执行。现在我有一个需求,要用 @awaitjs/express 来 decorate express,代码大概如下

    const express = require('express');
    const { decorateApp } = require('@awaitjs/express');
    const app = decorateApp(express());
    const port = 3000;
    
    function sleep(ms) {
      return new Promise(resolve => setTimeout(resolve, ms));
    }
    
    app.getAsync('/toggle', async function(req, res){
            let period = parseInt(req.query.period);
            let count = parseInt(req.query.count);
            
            res.json({success: true, message: "Power cycle schedueled successfuly for the interval of " + req.query.period + " minute(s), totaling " + req.query.count + " times."});
            while(count-- > 0){           
                   await do_something();
            }
            
            
        });
    await app.listen(port, () => console.log(`Example app listening on port ${port}!`))
    

    这个 res.json 后面的 while loop 是一个长时间执行的代码。我期望的是如前面第一个例子那样,在 res.json 返回客户端一个结果后继续执行 while loop。但是实际上这个 while loop 并不会运行,我哪里做的不对?

    1 条回复    2019-08-09 13:06:38 +08:00
    Hanggi
        1
    Hanggi  
       2019-08-09 13:06:38 +08:00
    不太建议你用这个 awaitjs/express,感觉实现不是很好。
    你这个程序,后面用 while await,那么这个长时间任务没做完之前,这个 api 应该不会返回,就挂在那里,直到做完。
    是这样吗?
    如果是的,那你这么实现就不对了,你应该是要这个接口返回成功,然后程序还在跑。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   996 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 118ms · UTC 21:12 · PVG 05:12 · LAX 13:12 · JFK 16:12
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.