用Promise实现前端并发请求

javascript 复制代码
/**
* 构造假请求
*/
async function request(url) {
  return new Promise((resolve) => {
    setTimeout(
      () => {
        resolve(url);
      },
      // Math.random() * 500 + 800,
      1000,
    );
  });
}

请求一次,查看耗时,预计应该是1s:

javascript 复制代码
async function requestOnce() {
  const t1 = Date.now();
  const res = await request(1);
  console.log('一次请求耗时=', Date.now() - t1, 'ms,请求结果=', res);
}
requestOnce();

结果:

12个数据发起并行请求,预计耗时1s:

javascript 复制代码
async function requestAsync() {
  const t2 = Date.now();
  const requests = new Array(12).fill(2).map(request);
  const res2 = await Promise.all(requests);
  console.log('批量请求耗时=', Date.now() - t2, 'ms,请求结果=', res2, ',预计是 1000 ms');
}

requestAsync();

结果:

12个请求并发进行,但限制最多3个请求可并发,预计耗时4s:

javascript 复制代码
async function concurrencyRequest(urls, maxNum) {
  const buffer = [];//并发请求池,最多有maxNum个
  const t3 = Date.now();
  const res = [];
  for (let i = 0; i < urls.length && buffer.length < maxNum; ++i) {
    // console.log('next=', i);
    const promise = new Promise((resolve) => request(urls[i]).then(resolve));
    buffer.push(promise);
    promise
      .then((response) => (res[i] = response))
      .finally(() => {//每个请求完成后都从buffer中删除并保存响应
        const index = buffer.findIndex((item) => item === promise);
        buffer.splice(index, 1);
        // console.log('删除一个promise', buffer.length);
      });
    if (buffer.length === maxNum) {//必须等待buffer size小于maxNum才能继续请求
      await Promise.race(buffer);
    }
  }
  await Promise.all(buffer);//需要等待最后剩下的几个请求完成才算完成
  console.log('并发请求耗时=', Date.now() - t3, '请求结果=', res, '预计时间是 4000 ms');
}

concurrencyRequest(
  new Array(12).fill(1).map((_, i) => i + 1),
  3,
);
相关推荐
NQBJT1 分钟前
VS Code配置Python人工智能开发环境
开发语言·人工智能·vscode·python
牛奶4 分钟前
AI双层代码治理:Monorepo × Harness Engineering
前端·aigc·ai编程
byoass8 分钟前
智巢AI知识库深度解析:企业文档管理从大海捞针到精准狙击的进化之路
开发语言·网络·人工智能·安全·c#·云计算
蜡台11 分钟前
H5使用Chrome 权限问题
前端·javascript·chrome
掘金一周18 分钟前
你们觉得房贷多少,没有压力 | 沸点周刊 4.30
前端·人工智能·后端
大貔貅喝啤酒18 分钟前
接口测试_Postman(详细版)
javascript·测试工具·node.js·自动化·postman
南境十里·墨染春水20 分钟前
C++笔记 STL——set
开发语言·c++·笔记
小小码农Come on20 分钟前
QML访问子项内容
前端·javascript·html
L16247621 分钟前
Win11 共享→Windows Server 访问故障总结(极简可复用)
开发语言·windows·php
桜吹雪33 分钟前
Langchain.js官方文档:构建具备按需加载技能的 SQL 助手
javascript·人工智能·node.js