Node.js worker_threads:并发 vs 并行

一、核心结论

Node.js 的 worker_threads 模块实现的是 并行计算 ,而非传统意义上的“并发”。其通过操作系统级线程实现多核 CPU 的并行执行,同时保留 Node.js 单线程事件循环的并发模型。

二、关键概念解析

1. 并发(Concurrency) vs 并行(Parallelism)

  • 并发

    • 指系统同时处理多个任务的能力,但任务可能交替执行(如单核 CPU 通过时间片轮转)。
    • Node.js 主线程 的事件循环是典型的并发模型,通过非阻塞 I/O 和事件队列实现。
  • 并行

    • 指多个任务同时执行,需多核 CPU 支持,每个任务运行在独立核心上。
    • worker_threads 通过创建操作系统级线程实现并行计算。

2. Node.js 的线程模型

  • 主线程

    • 单线程,运行事件循环,处理 I/O 和事件回调。
    • 阻塞主线程会导致整个进程卡顿。
  • Worker 线程

    • 每个 Worker 线程是独立的 JavaScript 运行时,拥有自己的事件循环和堆内存。
    • 线程由操作系统的系统线程支持,可绑定到不同 CPU 核心,实现并行执行。

三、worker_threads 的并行机制

1. 多核利用

  • 默认线程数

    • Node.js 根据 CPU 核心数自动创建线程池(通常等于核心数)。
    • 例如,4 核 CPU 默认创建 4 个线程,每个线程绑定到一个核心。
  • 任务分配

    • 主线程通过 Worker 类创建子线程,并将任务通过 postMessage 分发。
    • 子线程执行任务后,通过 parentPort.postMessage 返回结果。

2. 线程调度

  • 操作系统调度

    • Worker 线程由操作系统调度到不同 CPU 核心,实现真正的并行执行。
    • 线程间通过 SharedArrayBuffer 或消息传递通信,避免阻塞主线程。
  • 示例:并行计算斐波那契数列

    // main.js
    const { Worker } = require('worker_threads');
    const numCPUs = require('os').cpus().length;for (let i = 0; i < numCPUs; i++) {const worker = new Worker('./fibonacciWorker.js');worker.postMessage(40); // 每个线程计算第40个斐波那契数
    }
    
    // fibonacciWorker.js
    const { parentPort } = require('worker_threads');function fibonacci(n) {return n <= 1 ? n : fibonacci(n - 1) + fibonacci(n - 2);
    }parentPort.on('message', (n) => {const result = fibonacci(n);parentPort.postMessage(result);
    });
    

四、对比传统并发模型

1. 事件循环(主线程)

  • 特点

    • 单线程,通过非阻塞 I/O 和事件队列实现高并发。
    • 适合 I/O 密集型任务(如网络请求、文件操作)。
  • 局限

    • CPU 密集型任务会阻塞事件循环,导致其他任务无法执行。

2. Worker 线程(并行计算)

  • 特点

    • 多线程,利用多核 CPU 并行执行 CPU 密集型任务。
    • 线程间通过消息传递或共享内存通信,避免阻塞主线程。
  • 适用场景

    • 大型计算(如加密、图像处理、机器学习)。
    • 并行化数据库查询或数据处理任务。

五、性能监控与验证

1. 监控 CPU 核心利用率

  • Linux

    top -H -p <PID>  # 查看进程内所有线程的CPU使用率
    
  • Node.js

    const { threadId } = require('worker_threads');
    console.log(`Worker ${threadId} 正在运行`);
    

2. 并行计算验证

  • 示例:计算 π 的近似值(蒙特卡洛方法)

    // main.js
    const { Worker } = require('worker_threads');
    const numWorkers = 4;
    const totalSamples = 1e8;const workers = Array.from({ length: numWorkers }, (_, i) => {const worker = new Worker('./piWorker.js');worker.postMessage({ samples: totalSamples / numWorkers });return worker;
    });let results = [];
    workers.forEach((worker, i) => {worker.on('message', (result) => {results[i] = result;if (results.length === numWorkers) {const pi = results.reduce((sum, val) => sum + val) / numWorkers;console.log(`π ≈ ${pi}`);}});
    });
    
    // piWorker.js
    const { parentPort } = require('worker_threads');parentPort.on('message', ({ samples }) => {let inside = 0;for (let i = 0; i < samples; i++) {const x = Math.random();const y = Math.random();if (x * x + y * y <= 1) inside++;}parentPort.postMessage(4 * inside / samples);
    });
    

六、总结

  • worker_threads 是并行计算

    • 利用多核 CPU,通过操作系统级线程实现任务并行执行。
    • 适用于 CPU 密集型任务,避免阻塞主线程的事件循环。
  • 与主线程的并发模型互补

    • 主线程处理 I/O 和事件驱动的并发。
    • Worker 线程处理 CPU 密集型任务的并行计算。

通过合理使用 worker_threads,您可以充分发挥多核 CPU 的性能优势,构建高效、响应迅速的 Node.js 应用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/913612.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/913612.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

gloo 多卡训练

我们遇到了分布式训练中的通信超时问题&#xff08;Connection closed by peer&#xff09;。根据错误信息&#xff0c;问题发生在梯度同步的屏障&#xff08;barrier&#xff09;操作时。以下是针对此问题的优化措施和代码修改&#xff1a; 优化措施&#xff1a; 增强通信稳…

【Docker】在银河麒麟ARM环境下离线安装docker

1、前言 采用离线安装的方式。 关于离线安装的方式官网有介绍&#xff0c;但是说的很简单&#xff0c;网址&#xff1a;Binaries | Docker Docs 官网介绍的有几种主流linux系统的安装方式&#xff0c;但是没有kylin的&#xff0c;所以在此记录一下。 在安装过程中也遇到了些…

AUTOSAR进阶图解==>AUTOSAR_SWS_SOMEIPTransformer

AUTOSAR SOME/IP 转换器规范详解 基于AUTOSAR标准的SOME/IP转换器协议解析与实现指南目录 1. 介绍与功能概述2. SOME/IP架构 2.1 SOME/IP转换器架构2.2 组件解释2.3 层级说明 3. SOME/IP通信流程 3.1 客户端/服务器通信序列3.2 通信流程解释 4. SOME/IP消息结构 4.1 消息结构类…

Python 机器学习核心入门与实战进阶 Day 5 - 模型调参与交叉验证技巧(GridSearchCV、KFold)

✅ 今日目标 理解模型调参的重要性&#xff08;避免欠拟合/过拟合&#xff09;掌握 GridSearchCV 的使用方法学习 K 折交叉验证的基本流程与意义对比不同参数组合的表现使用 Pipeline 简化流程&#xff08;进阶&#xff09;&#x1f4d8; 一、调参思路方法描述Grid Search穷举所…

Python打卡:Day47

复习日 浙大疏锦行

ACE-Step:AI音乐生成基础模型

ACE-Step是什么 ACE-Step 是 ACE Studio 和 StepFun 联合推出的一款开源音乐生成基础模型&#xff0c;专为高效、连贯、可控的音乐创作而设计。它融合了扩散模型、深度压缩自编码器&#xff08;DCAE&#xff09;和轻量级线性变换器&#xff0c;生成速度比传统大模型快约 15 倍…

Web前端: :is(通用选择器)

:is(通用选择器)CSS中的 :is() 选择器是⼀个功能强⼤的伪类选择器&#xff0c;它⽤于简化复杂的选择器&#xff0c;特别是在处理多个相似的选择器时。:is() 选择器接受 ⼀个选择器列表作为参数&#xff0c;然后匹配列表中任何⼀个选择器所选中的元素。:is() 选择器核心概念基本…

【学习笔记】网络设备(华为交换机)基础知识 24 —— 以太网子接口基础知识

**总结&#xff1a;分享华为交换机以太网子接口基础知识&#xff1a;包含子接口的简介、功能、分类以及二层以太网子接口配置终结子接口、三层以太网子接口配置终结子接口和检查配置结果的相关命令 ** 一、子接口的概念 1、子接口的简介以太网子接口&#xff1a;‌是通过协议和…

在Docker中安装nexus3(作为maven私服)

1. 为什么我不推荐安装nexus2&#xff1f; 有两个原因&#xff1a;&#xff08;1&#xff09;nexus2安装麻烦&#xff0c;nexus3安装更方便 &#xff08;2&#xff09;Nexus 3相对于Nexus 2进行了一些重要的改进和增强。它引入了新的存储引擎、更多的仓库类型支持、改进的权限…

一、MySQL 8.0 之《EXPLAIN ANALYZE 执行计划》

文章目录一、MySQL EXPLAIN ANALYZE 执行计划指南主要功能实际执行性能分析详细的执行统计性能瓶颈识别与普通 EXPLAIN 的区别使用场景查询优化问题诊断总结二、EXPLAIN ANALYZE 执行计划样例分析执行顺序解读逐行详细解释第 7 行 (最内层)第 6 行第 5 行第 4 行第 3 行第 2 行…

Google I/O Extended :2025 Flutter 的现状与未来

大家好&#xff0c;我是 Flutter GDE 郭树煜&#xff0c;Github GSY 项目的维护人&#xff0c;今天主要分享的内容是「Flutter 的现状与未来」&#xff0c;可能今天更多会是信息科普类型的内容&#xff0c;主要是分享关于 Flutter 的现状与未来 现状 其实 Flutter 从开源到现在…

软考(软件设计师)数据库原理:事务管理,备份恢复,并发控制

数据库事务管理与备份恢复 事务&#xff08;Transaction&#xff09; 是数据库管理系统中执行的一个不可分割的工作单元&#xff0c;它包含一组 SQL 操作&#xff0c;这些操作要么全部成功执行&#xff0c;要么全部不执行。 事务的四大特性&#xff08;ACID&#xff09;&…

【牛客刷题】相遇

文章目录 一、题目介绍1.1 题目描述1.2 输入描述1.3 输出描述1.4 示例二、解题思路2.1 核心算法设计2.2 性能优化关键2.3 算法流程图三、解法实现3.1 解法一:基础实现3.1.1 初级版本分析3.2 解法二:优化版本(推荐)3.2.1 优化版本分析一、题目介绍 1.1 题目描述 街道可以看…

uni-app 下拉搜索多选 支持自己创建数据

组件 /components/selectmul.vue <template><view class="multi-select-container"><view class="input-dropdown-container"><view class="" v-if="selectlist&&selectlist[0]"><text class=&qu…

nmon使用方法

安装方法 方法1&#xff1a; 最简单方法&#xff1a; #dnf install nom 验证 执行命令&#xff1a; #nmon 方法2&#xff1a; 下载安装包安装&#xff0c;下载地址 官网&#xff1a;nmon and njmon | Site / Download 或者&#xff1a;https://sourceforge.net/project…

Google AI 刚刚开源 MCP 数据库工具箱,让 AI 代理安全高效地查询数据库

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

数学建模的一般步骤

归纳编程学习的感悟&#xff0c; 记录奋斗路上的点滴&#xff0c; 希望能帮到一样刻苦的你&#xff01; 如有不足欢迎指正&#xff01; 共同学习交流&#xff01; &#x1f30e;欢迎各位→点赞 &#x1f44d; 收藏⭐ 留言​&#x1f4dd; 青春由磨砺而出彩&#xff0c;人生因奋…

【web安全】SQLMap 参数深度解析:--risk 与 --level 详解

目录 简介 一、--risk 参数&#xff1a;测试风险控制 1. 基本定义 2. 各级别详细对比 risk1 (默认) risk2 risk3 3. 使用建议 二、--level 参数&#xff1a;测试深度控制 1. 基本定义 2. 各级别详细对比 level1 (默认) level2 level3 level4 level5 3. 技术实…

YOLO在自动驾驶交通标志识别中的应用与优化【附代码】

文章目录YOLO在自动驾驶交通标志识别中的应用与优化引言1. YOLO算法概述1.1 YOLO的核心思想1.2 YOLO的演进2. 交通标志识别的挑战2.1 数据集特性2.2 性能指标要求3. YOLO模型优化策略3.1 数据增强改进3.2 注意力机制集成3.3 针对小目标的改进4. 完整实现示例4.1 模型训练代码4.…

开源鸿蒙(OpenHarmony)桌面版全面解析:架构适配、设备支持与开发实战

摘要:深度剖析OpenHarmony 4.0+桌面版的技术演进,揭秘其在X86/国产芯片设备的落地实践,附源码获取与开发板实战指南 一、OpenHarmony桌面版架构突破 1.1 跨平台内核适配 开源鸿蒙通过 多内核混合架构 实现全场景覆盖: X86架构:集成Linux内核适配层(kernel/linux),支持…