我的编程空间,编程开发者的网络收藏夹
学习永远不晚

如何使用p-limit限制并发数

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

如何使用p-limit限制并发数

这篇文章主要讲解了“如何使用p-limit限制并发数”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用p-limit限制并发数”吧!

使用

下面是官方提供的使用示例:

import pLimit from 'p-limit';const limit = pLimit(1);const input = [limit(() => fetchSomething('foo')),limit(() => fetchSomething('bar')),limit(() => doSomething())];// Only one promise is run at onceconst result = await Promise.all(input);console.log(result);

在代码的第一行,使用了 pLimit(1) 来创建一个 p-limit 实例,并将并发限制设为 1。这意味着,在任意时刻,只能有一个 Promise 在运行。

在第四行,使用了 limit(() => fetchSomething('foo')) 来包装一个异步函数,并返回一个 Promise。同样的方式,在第五、六行也包装了其他两个异步函数。

最后,使用 Promise.all 方法来等待所有 Promise 的完成,并在完成后将结果输出到控制台。由于 p-limit 的限制,这些 Promise 只会按顺序一个一个地运行,保证了并发的数量不会超过 1。

源码分析

import Queue from 'yocto-queue';export default function pLimit(concurrency) {if (!((Number.isInteger(concurrency) || concurrency === Number.POSITIVE_INFINITY) && concurrency > 0)) {throw new TypeError('Expected `concurrency` to be a number from 1 and up');}const queue = new Queue();let activeCount = 0;}

yocto-queue 是一种允许高效存储和检索数据的数据结构。前边的章节分析过它的源码,详情参见: 源码共读|yocto-queue 队列 链表

pLimit 函数接受一个参数,并发数,首先函数判断参数是否是数组类型,或者是否能够转换成数字类型,如果不能,抛出一个错误。

之后定义了一个队列来存储待执行的函数,并使用一个计数器来记录当前正在运行的函数的数量。

const next = () => {activeCount--;if (queue.size > 0) {queue.dequeue()();}};const run = async (fn, resolve, args) => {activeCount++;const result = (async () => fn(...args))();resolve(result);try {await result;} catch {}next();};

在代码的 next 函数中,如果队列不为空,则从队列中取出一个函数并执行。这个函数的执行会导致计数器的值减 1。

在代码的 run 函数中,使用了 async/await 语法来执行传入的函数 fn。它还使用了 resolve 函数将函数的返回值包装成一个 Promise,并将这个 Promise 返回给调用者。在函数执行完成后,调用 next 函数来执行下一个函数。

const enqueue = (fn, resolve, args) => {queue.enqueue(run.bind(undefined, fn, resolve, args));(async () => {// This function needs to wait until the next microtask before comparing// `activeCount` to `concurrency`, because `activeCount` is updated asynchronously// when the run function is dequeued and called. The comparison in the if-statement// needs to happen asynchronously as well to get an up-to-date value for `activeCount`.await Promise.resolve();if (activeCount < concurrency && queue.size > 0) {queue.dequeue()();}})();};

在代码的 enqueue 函数中,使用了 queue.enqueue 方法将传入的函数 fn 加入队列。然后,它使用了 async/await 语法来在下一个微任务中检查当前的并发数量是否小于设定的并发限制。如果是,则从队列中取出一个函数并执行。

const generator = (fn, ...args) => new Promise(resolve => {enqueue(fn, resolve, args);});Object.defineProperties(generator, {activeCount: {get: () => activeCount,},pendingCount: {get: () => queue.size,},clearQueue: {value: () => {queue.clear();},},});return generator;

在代码的 generator 函数中,使用了 new Promise 语法来生成一个新的 Promise,并在其中调用了 enqueue 函数。这样,每次调用生成的函数时,都会生成一个新的 Promise,并将函数加入队列。

最后,使用了 Object.defineProperties 方法来为生成的函数添加属性。这些属性可以用来查询当前的并发数量和等待队列的大小,以及清空等待队列。

感谢各位的阅读,以上就是“如何使用p-limit限制并发数”的内容了,经过本文的学习后,相信大家对如何使用p-limit限制并发数这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

如何使用p-limit限制并发数

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何使用p-limit限制并发数

这篇文章主要讲解了“如何使用p-limit限制并发数”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用p-limit限制并发数”吧!使用下面是官方提供的使用示例:import pLimi
2023-07-04

使用p-limit 限制并发数源码解析

这篇文章主要为大家介绍了使用p-limit 限制并发数源码解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-12-25

Nginx中如何使用limit模块限制并发数

小编给大家分享一下Nginx中如何使用limit模块限制并发数,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧! nginx 限制ip并发数,nginx限制IP连接数的范例参考:如何Nginx限制同一个ip的连接数,限制并发数
2023-06-04

nginx如何限制php并发数

要限制PHP并发数,可以使用Nginx的limit_conn_module模块。该模块可以限制对某个特定的location或server的并发连接数。首先,确保你的Nginx已经编译安装了limit_conn_module模块。可以使用ng
2023-08-24

JavaScript使用Promise实现并发请求数限制

本文主要介绍了JavaScript使用Promise实现并发请求数限制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-05-16

JavaScript怎么使用Promise实现并发请求数限制

本篇内容主要讲解“JavaScript怎么使用Promise实现并发请求数限制”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript怎么使用Promise实现并发请求数限制”吧!没有
2023-07-06

如何使用golang函数并发控制进行并行计算

在 go 中可以使用 goroutine 和函数并发控制实现并行计算,具体步骤如下:创建 goroutine,使用 go 关键字创建轻量级并发执行单元。使用 sync.waitgroup 类型管理 goroutine,协调并行执行。将任务分
如何使用golang函数并发控制进行并行计算
2024-04-24

MySQL 8.0限制用户并发连接数的两个参数

MySQL 8.0限制用户并发连接数的两个参数 max_connectionsmax_user_connections max_connections 针对所有用户总体而言,MySQL Server允许的最大并发客户端连接数,默
2023-08-17

使用Nginx限制IP请求和并发连接数的实现方法

Nginx可用于限制IP请求和并发连接数,增强Web服务器安全性。限制IP请求可根据单个IP地址或子网范围设置请求数量上限。并发连接数限制则可限制单个IP地址或连接速率。Nginx提供自定义配置选项,包括burst、nodelay、log_level和status,以定制限制策略。需要注意的是,限制过于严格或被规避,可能会对合法用户或性能造成影响。
使用Nginx限制IP请求和并发连接数的实现方法
2024-04-02

如何限制Golang GRPC中客户端的并发连接

php小编鱼仔将为大家介绍如何限制Golang GRPC中客户端的并发连接。在使用Golang进行开发时,我们常常会使用GRPC来进行服务间的通信。然而,如果不加以限制,客户端可能会因为并发连接过多而导致性能下降或者服务器负载过高。因此,合
如何限制Golang GRPC中客户端的并发连接
2024-02-08

java并发ThreadPoolExecutor如何使用

这篇文章主要介绍“java并发ThreadPoolExecutor如何使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“java并发ThreadPoolExecutor如何使用”文章能帮助大家解决问
2023-07-05

golang并发锁如何使用

这篇文章主要介绍了golang并发锁如何使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇golang并发锁如何使用文章都会有所收获,下面我们一起来看看吧。如果程序用到的数据是多个groutine之间的交互过程
2023-07-05

怎么利用限制并发连接数来防御DDoS攻击

限制并发连接数是一种常见的防御DDoS攻击的方法,可以有效地减缓攻击对服务器的影响。以下是一些利用限制并发连接数来防御DDoS攻击的方法:设置最大连接数限制:通过在服务器上设置最大连接数限制,可以防止单个IP地址同时建立过多的连接。这样可以
怎么利用限制并发连接数来防御DDoS攻击
2024-04-15

Linux中如何使用cgroups限制cpu

这篇文章主要讲解了“Linux中如何使用cgroups限制cpu”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Linux中如何使用cgroups限制cpu”吧!cgroups 里,可以用 c
2023-06-13

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录