nodejs多线程,fork和Worker

一、前言

javascript是单线程执行的,如果想要多线程执行,那么相当于再运行一个node,其实不该理解成多线程,更像是多进程。

二、Worker('worker_threads'模块)

worker有点类似exec,直接再cmd执行node命令,不同的是两个node进程之间可以通过发送消息的方式进行通信。

例如(例子为ts):

主进程中:

javascript 复制代码
// 当前为test2.ts 文件
import {Worker, isMainThread} from 'worker_threads'

async function  runWork():Promise<void>{
    // 当前是主线程
    if(isMainThread){
          //const log= execSync("ts-node ./test.ts",{cwd:__dirname}).toString()
        // 运行子线程--相当于输入node-ts  ./test.ts
        const woker =new Worker("./test.ts",{workerData:"hello"}) 
        // 监听事件
        // message 为固定事件 
        // error 事件 子线程的错误信息
        // exit 事件 子线程执行完毕 时候的事件
        woker.on("message",(data:string)=>{
             console.log("主线程接收数据:"+data);
       })
    }
    
    console.log("主线程");
    
}
runWork()

子进程中:

javascript 复制代码
// test.ts文件 注意:子进程不支持ES6语法

const worker_threads=require('worker_threads') 
console.log("线程2,接收数据"+worker_threads.workerData);
// 向主进程发送数据
worker_threads.parentPort.postMessage("hello2")

worker 只能在主进程中创建,不能在子进程中再创建

三、fork(child_process模块)

fork比worker出现得早,于worker相比,它可以在子线程再创建子线程,但是worker更轻量.

例子(ts):

主线程:

javascript 复制代码
// 当前为 test3.ts文件 主进程

// 引入模块
const { fork } = require('child_process');

// 创建子进程
const child = fork('test33.ts');

// 监听子进程发送的消息
child.on('message', (data:string) => {
   
        console.log("接收的消息:"+data);
    

});

// 向子进程发送消息
child.send('Hello from parent process!');

子进程:

javascript 复制代码
// 当前为 test33.ts 文件 子进程

const child_process=require("child_process")
// 向父进程发送消息
if(typeof process.send!='undefined'){
    process.send('你们好主进程');
}

总结:nodejs的多线程不像java那样,它更像是运行了多个node

相关推荐
眠りたいです2 小时前
现代C++:C++11并发支持库
开发语言·c++·多线程·c++11·c++并发支持库
冉佳驹8 小时前
Linux ——— Git的核心操作流程、进程状态及环境变量相关知识
linux·git·进程·环境变量·进程状态·fork
2401_841495641 天前
【自然语言处理】中文文本字频统计与交互式可视化工具
人工智能·python·自然语言处理·多线程·分块读取·文本分析·字频统计
Irene19911 天前
Worker() 构造函数第二个参数详解(附:凭证模式详解)
worker
为什么要做囚徒1 天前
并发系列(一):深入理解信号量(含 Redis 分布式信号量)
redis·分布式·多线程·并发编程·信号量
Irene19912 天前
Worker 线程中的 函数序列化 模式
worker·函数序列化
努力发光的程序员3 天前
互联网大厂Java求职面试实录
java·jvm·线程池·多线程·hashmap·juc·arraylist
Da Da 泓3 天前
多线程(四)【线程安全问题】
java·开发语言·jvm·学习·安全·多线程·线程安全问题
Brookty3 天前
Java并发编程核心的基础知识
java·开发语言·java-ee·多线程·线程安全
羑悻的小杀马特5 天前
C++多线程同步工具箱:call_once精准触发、lock_guard/unique_lock智能管理,打造无死锁程序!
c++·多线程·死锁·lock_guard·unique_lock·call_once