用 request 包发了几大波请求,然后它好像阻塞了,可能是什么原因

2016-06-17 21:37:01 +08:00
 billlee

概述

其实不是阻塞,但不知道怎么用一句话描述,具体现象后面有详细讲。

用的是 request. 伪代码如下


let count = 100;

function batch() {
  // 从数据库用 SELECT ... LIMIT 100 取出 100 条 url
  for (let url in urlList) {
    const req = request(...);
    req.on('error', () => {
      // 一些其它操作
      count--;
      if (count === 0) {
        count = 100;
        batch();
      }
    });
    req.on('end', () => {
      // 一些其它操作
      count--;
      if (count === 0) {
        count = 100;
        batch();
      }
    });
  }

第一波发出去的请求是正常的,过了几波后,在创建完 request, 控制权交还给事件循环时, 要等好长时间才会开始发请求,这个等待的时间会越来越久。试过调整连接池,但只能缓解,不能解决。

大家有没有碰到过类似的问题?或者有没有排查问题的思路?

等待发请求时的具体现象

2969 次点击
所在节点    Node.js
3 条回复
magicdawn
2016-06-17 21:56:09 +08:00
batch 里的循环没有引用 count, 在 error/end 修改 end 有什么用...
你这样一下创建了 n 多请求, 会导致系统打开的 fd 急剧增加...

如果你是使用 callback 的话可以使用 async.parallelLimit, see https://github.com/caolan/async#paralleltasks-callback
promise, co, 或者 async/await 可以使用 promise.map 控制下并发, see https://github.com/magicdawn/promise.map
magicdawn
2016-06-17 21:57:30 +08:00
> 在 error/end 修改 end 有什么用...

在 error/end 修改 count 有什么用...
billlee
2016-06-17 22:24:33 +08:00
@magicdawn 我的目的就是并发很多请求,因为这些 url 大部分是无法访问的。
修改 count 这个先不管吧,这是伪代码(公司政策不允许外发代码),实际代码这里肯定是没问题的,因为打印的日志显示计数从 100 降到 0 了,并且 batch 也已经被调用了。

async.parallel 看起来不错,下周我去换上。不过这个应该不是关键问题吧,我这也相当于是自己实现了 async.parallel 的功能。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/286567

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX