当前位置: 首页 > article >正文

用Promise实现前端并发请求

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

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

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

结果:在这里插入图片描述

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

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:

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,
);

在这里插入图片描述


http://www.kler.cn/a/329318.html

相关文章:

  • 【Java】阿里环球Antom支付对接
  • 使用插件SlideVerify实现滑块验证
  • 每日一刷——1.20——准备蓝桥杯
  • springBoot项目使用Elasticsearch教程
  • K8S中Pod控制器之Job控制器
  • 回归算法、聚类算法、决策树、随机森林、神经网络
  • Win10鼠标总是频繁自动失去焦点-非常有效-重启之后立竿见影
  • Bigemap Pro首发(一款真正全面替代Arcgis的国产基础软件)
  • Linux Mint急救模式
  • 英伟达Ampere架构和Hopper架构技术解析
  • C++(Qt)软件调试---内存调试器Dr.Memory(21)
  • 模拟实战数据落地:MSsql通过存储过程获得销售数据视图
  • Ubuntu20.04中ros2 foxy版本安装gazebo,并运行小车运动demo
  • Java中使用接口实现回调函数的详解与示例
  • C语言、Eazy_X——五子棋
  • 零知识证明在BSV网络上的应用
  • 高度细化的SAGA模式实现:基于Spring Boot与RabbitMQ的跨服务事务
  • 甄选范文“论软件的可靠性设计”,软考高级论文,系统架构设计师论文
  • Vue页面,基础配置
  • 机器学习模型评估
  • Web APIs 4:日期对象、时间戳、节点操作、swiper插件
  • VS code user setting 与 workspace setting 的区别
  • 前端规范工程-2:JS代码规范(Prettier + ESLint)
  • consul 介绍与使用,以及spring boot 项目的集成
  • Servlet——springMvc底层原理
  • 苏州 数字化科技展厅展馆-「世岩科技」一站式服务商