iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >node可不可以开启多线程
  • 627
分享到

node可不可以开启多线程

2024-04-02 19:04:59 627人浏览 薄情痞子
摘要

本文小编为大家详细介绍“node可不可以开启多线程”,内容详细,步骤清晰,细节处理妥当,希望这篇“node可不可以开启多线程”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

本文小编为大家详细介绍“node可不可以开启多线程”,内容详细,步骤清晰,细节处理妥当,希望这篇“node可不可以开启多线程”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

node可以开启多线程;可以利用node自带的“child_process”模块来开启多线程,语法为“child_process.fork(modulePath[, args][, options])”;使用该模块可以创建exec、execFile、spawn、fork四种类型的子进程。

教程操作环境:windows10系统、nodejs 12.19.0版本、Dell G3电脑。

node可以开启多线程吗

node可以开启多线程

我们都知道 node.js 是以单线程的模式运行的,但它使用的是事件驱动来处理并发,基于事件驱动、非阻塞I/O模型,充分利用操作系统提供的异步 I/O 进行多任务的执行,适合于 I/O 密集型的应用场景,因为异步,程序无需阻塞等待结果返回

Nodejs多线程的出现不为了提高并发,而是为了充分提高CPU的利用率

开多线程的几种方式

使用Node自带的 child_process 模块

child_process.fork(modulePath[, args][, options])

衍生新的 Node.js 进程并使用建立的 IPC 通信通道(其允许在父子进程之间发送消息)调用指定的模块

cluster 集群模块可以轻松创建共享服务器端口的子进程 ,工作进程使用 child_process.fork() 方法衍生

node可不可以开启多线程

使用多进程

express

新建三个文件 server.js(express服务) cluster.js(多线程服务文件)extensionServer.js (express 子服务)
下面操作确保安装 express

npm intsall express --seve-dev

extensionServer.js 使用express 创建 子服务
const express = require("express"), //Express框架
app = express();

// api 先关接口
app.all('/userinfo', (req, res) => {
  res.JSON({ name: '自夏', msg: '我在自夏 selfsummer' })
})

app.listen(4000, () => {
 console.log(`子服务启动成功`);
})
serve.js 先创建Express 多线程 服务
const  { fork } = require("child_process"),
express = require("express"), //Express框架
app = express();

const { pid, ppid } = require('process')

// api 先关接口
app.all('/123', (req, res, next) => {
   console.log(`本次进程id为: ${pid}`);
  res.end(`本次进程id为: ${pid}`)
})

app.all('/456', (req, res, next) => {
  console.log(`本次进程id为: ${pid}`);
  res.end(`本次进程id为: ${pid}`)
})


app.listen(3888, () => {
 console.log(`服务器端启动成功 父进程 ${ppid} 当前服务进程id为 ${pid}`);
 // 开启多进程
 fork('extensionServer.js')
})

module.exports = {
  app,
  express,
};

启动服务 这个时候主服务和自服务都启动好了

node可不可以开启多线程

访问 Express 主服务 以及子服务地址都可成功

cluster.js 把Express 服务改为集群

使用 cluster集群模块开启多线程

const os = require('os');
const cluster = require('cluster');
const { log } = console;
const express = require("express"); //Express框架

const app = express();
const processId = process.pid;

// 判断当前是否有主进程
if (cluster.isMaster)
{
	// 获取当前本机cpu核数,开启多线程
  const cpus = os.cpus().length;
  for (let i = 0; i < cpus; i++){
    cluster.fork()
  }
	//进程已断开连接	
	  cluster.on('disconnect', (worker) => {
	    console.log(`进程号 #${worker.id} 已断开`);
	  });
	// 意外退出进程
	cluster.on('exit', (worker, code, signal) => {
	      cluster.fork();
  	});


} else
{
	// 引用Express主服务 开启主进程  
  require('./server')
}

启动集群服务 node cluster

当然也可以在集群里面继续开子进程

访问二次(一个浏览器访问,一个Postman 访问)后接口
node可不可以开启多线程

为什么会有多个 服务器端启动成功 当前服务进程id为 xxx

应为 cluster 模块在 当前主进程下面衍生子进程,每一个子进程是基于主进程的所有
衍生新的进程,进程之间是相互独立的,每个进程都有自己的 V8 实例、内存,系统资源是有限的,不建议衍生太多的子进程出来,通长根据系统*
CPU 核心数*设置

前面我们有判断是否是有主进程

如果有主进程就 使用 cluster 模块 开启 子进程

没有就开启进程

把Express 服务改为 默认Http 服务

只需要更改server.js 文件内容

const http = require('http')const { pid, ppid } = require('process')const server = http.createServer((req, res) => {
  res.end(router(req.url))})const router = (url) => {
  switch (url)
  {
    case '/132':
      return `进程${pid} 很高兴为你服务`;
    case '/456':
      return `进程${pid} 很高兴为你服务`;
    default: return `没有此接口`
  }}server.listen(3889, () => {
  console.log(`Server Started in process ${pid}`);})

依旧是启动 cluster.js(多线程服务文件)
node可不可以开启多线程

读到这里,这篇“node可不可以开启多线程”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网JavaScript频道。

--结束END--

本文标题: node可不可以开启多线程

本文链接: https://www.lsjlt.com/news/98096.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • node可不可以开启多线程
    本文小编为大家详细介绍“node可不可以开启多线程”,内容详细,步骤清晰,细节处理妥当,希望这篇“node可不可以开启多线程”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。 ...
    99+
    2024-04-02
  • JavaScript可以不开启吗
    JavaScript是一种广泛使用的编程语言,它在当前的互联网世界中扮演着非常重要的角色。许多网站都需要JavaScript才能正常运行,因此很多人认为在访问网站时需要开启JavaScript。但实际上,是否开启JavaScript是由访问...
    99+
    2023-05-14
  • linux可不可以创建多个进程
    这篇“linux可不可以创建多个进程”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“linu...
    99+
    2023-02-07
    linux
  • javascript可不可以开发游戏
    小编给大家分享一下javascript可不可以开发游戏,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧! javascript可以开发游戏,JavaScript实现...
    99+
    2024-04-02
  • win10更新卡住不动可不可以重启
    本篇内容介绍了“win10更新卡住不动可不可以重启”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!尽量耐心点(可能会导致硬盘报废)直接长按关键...
    99+
    2023-07-01
  • html5中可不可以有多个form
    这篇文章主要介绍了html5中可不可以有多个form的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇html5中可不可以有多个form文章都会有所收获,下面我们一起来看看吧。 ...
    99+
    2024-04-02
  • go语言可不可以编程
    本篇内容主要讲解“go语言可不可以编程”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“go语言可不可以编程”吧!go语言可以编程。Go语言是由Google公司开发的一种静态强类型、编译型、并发型、...
    99+
    2023-07-04
  • react中可不可以使用事件总线
    本篇文章和大家了解一下react中可不可以使用事件总线。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。 react中可以使用事件总线;react使用事件总线可以...
    99+
    2024-04-02
  • php可不可以安装多个版本
    这篇文章主要讲解了“php可不可以安装多个版本”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“php可不可以安装多个版本”吧!php可以安装多个版本。安装多个版本的PHP需要在同一IIS服务器...
    99+
    2023-06-30
  • python的多线程原来可以这样解
    目录多线程创建线程总结多线程 多线程类似于同时执行多个不同程序,多线程运行有如下优点: 使用线程可以把占据长时间的程序中的任务放到后台去处理。用户界面可以更加吸引人,比如用户点击了一...
    99+
    2024-04-02
  • go语言可不可以开发接口
    本篇内容主要讲解“go语言可不可以开发接口”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“go语言可不可以开发接口”吧!go语言可以开发接口。go语言中接口是一组方法的签名,它是go语言中重要的组...
    99+
    2023-07-04
  • windows system进程可不可以关掉
    这篇文章主要介绍“windows system进程可不可以关掉”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“windows system进程可不可以关掉”文章能帮助大家解决问题。system是什么进...
    99+
    2023-07-02
  • win10更新太慢了可不可以关机重启
    这篇“win10更新太慢了可不可以关机重启”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“win10更新太慢了可不可以关机重启...
    99+
    2023-07-02
  • es6数组中可不可以用展开符
    这篇文章主要讲解了“es6数组中可不可以用展开符”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“es6数组中可不可以用展开符”吧!es6数组可以用展开符。展开符“...”会将可迭代对象展开到其...
    99+
    2023-07-04
  • vue可以开发多页面吗
    Vue是一个非常流行的JavaScript库,被广泛用于开发单页面应用程序(SPA)。 Vue为SPA开发提供了很多方便的工具和技术,但是对于那些需要开发多个页面的应用程序而言,SPA并不是一个理想的选择。在这种情况下,开发人员可以使用Vu...
    99+
    2023-05-14
  • Java线程同步与互斥:多线程编程的基石,不可不知
    多线程是计算机编程中一个重要的概念,它允许程序同时执行多个任务,从而提高程序的效率。然而,使用多线程时可能会遇到一些问题,其中之一就是共享资源的多线程冲突。 共享资源是指多个线程可以同时访问的资源,如全局变量或文件等。当多个线程同时访问...
    99+
    2024-02-09
    Java 线程 同步 互斥 关键字 volatile 原子变量
  • 云服务器可以多开吗
    云服务器可以多开,但是具体的多开方式和限制取决于云服务提供商和你所选择的云服务器实例类型。一般来说,云服务器实例可以通过创建多个实例来实现多开,每个实例都有自己的独立 IP 地址和资源。你可以根据自己的需求选择不同的实例类型和数量来满足多开...
    99+
    2023-10-26
    服务器 多开吗
  • 英语零基础可不可以学Java编程
    小编给大家分享一下英语零基础可不可以学Java编程,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!其实编程能用到的英文没有浩如烟海,大家常用的命令不算多。在JAVA...
    99+
    2023-06-04
  • python怎么开启多线程
    要开启python中的多线程:创建线程对象,指定要执行的任务和参数。启动线程,使其开始执行目标函数。根据需要,使用join()方法等待线程完成。 如何在 Python 中开启多线程 多...
    99+
    2024-05-14
    python
  • jquery中多个元素可不可以绑定一个事件
    这篇文章将为大家详细讲解有关jquery中多个元素可不可以绑定一个事件,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 jquery中多个元素可...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作