多图片上传案例:多个图片同时上传,请求的并发控制

思路

  • 创建一个请求队列,存储并发请求
  • 创建一个请求调度器,用于控制请求的并发
  • 设置允许的最大并发数量
  • 计算当前正在执行的请求的数量
  • 一个请求完成后,继续从请求队列中取出剩余的任务,调度执行

整体架构流程

请求队列:

class Queue {
  // 请求队列
  tasks = [];
  // 将请求推入tasks队列
  enqueue(task) {
    this.tasks.push(task);
  }
  // 将请求从队列中取出
  dequeue() {
    return this.tasks.shift();
  }
  // 当前队列中的请求数量
  size() {
    return this.tasks.length;
  }
}

请求调度器:

export class RequestScheduler {
  requests = new Queue();
  // 最大并发数量
  maxConcurrentNum;
  // 记录当前已经发送但未完成的请求数量
  currentRequestNum = 0;
  constructor(maxConcurrentNum = 2) {
    this.maxConcurrentNum = maxConcurrentNum;
  }
  // 将请求添加到队列
  addRequest(request) {
    this.requests.enqueue(request);
    this.next();
  }
  
  async next() {
    if (this.requests.size() > 0) {
      // 判断是否达到最大并发数
      if (this.currentRequestNum < this.maxConcurrentNum) {
        this.currentRequestNum++;
        // 从队列中取出任务执行
        const request = this.requests.dequeue();
        await request();
        this.currentRequestNum--;
        // 任务执行完后,继续调用,看请求队列中是否还有请求未发送
        this.next();
      }
    }
  }
}

接口请求:

const requestScheduler = new RequestScheduler(3);
// 多个图片上传
const onUploadImage = (images) => {
  images.forEach(async (file) => {
    // 上传接口
    requestScheduler.addRequest(async () => {
      const res = await uploadImage(file);
      console.log(res);
    });
  });
};

api

export const uploadImage = (img) => {
  const formData = new FormData();
  formData.append("image", img);
  return requestClient.post("/images/upload", formData, {
    headers: {
      "Content-Type": "multipart/form-data",
    },
  });
};

小结

菜就多练
加油

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值