Nodejs架构

news2025/2/28 19:47:19

Node.js 是一个开源的 JavaScript 运行时环境,旨在运行可扩展的应用程序。 Node.js 允许开发人员使用 JavaScript 编写服务器端脚本代码。此外,Node.js 具有能够异步 I/O 的事件驱动架构。它基于 Google Chrome 的 V8 引擎构建,用于开发I/O 密集型 Web 应用程序,例如视频流、单页应用程序、在线聊天应用程序和其他网页。在本文中,我将讨论 Node.js 架构,并深入探讨 Node.js 内部更小的组件。

可以将 Node.js 架构分为两个主要组件:V8 引擎和 LIBUV。下边分别看看每个组件的功能。

V8 Engine

V8 引擎是 Node.js 架构的基础部分。如果没有 V8 引擎,就无法识别 JavaScript。 V8引擎帮助将JavaScript代码转换为机器可以理解代码。

LIBUV

LIBUV 是一个专注于异步 I/O 的开源库。该库提供Node.js 对计算机操作系统、文件系统和网络的访问。以下是 LIBUV 的一些功能

  • 异步TCP(net模块)和UDP(dgram模块)
  • 异步DNS解析(部分用于DNS模块)
  • 异步文件、文件系统操作和事件(fs 模块)
  • ANSI 转义码控制的 TTY
  • 线程池和信号处理
  • 子进程
  • 高分辨率时钟
  • 线程和同步原语。
  • 使用套接字和 Unix 域套接字 (Windows) 进行进程间通信

事件队列(Event Queue)、事件循环(Event Loop)和线程池(Thread Pool)是LIBUV中最重要的组件。

Event Queue 事件队列

事件队列将传入的客户端请求按顺序传递给事件循环

Event Loop 事件循环

事件循环负责处理小任务,例如执行回调函数或网络 I/O。这些是非阻塞任务,不会阻塞主线程。它负责处理所有传入事件,并通过将较繁重的任务卸载到线程池中并自行执行较简单的任务来执行平衡负载。以下是事件循环的一些功能

  • 事件循环是一个无限循环,它等待任务,执行它们,然后休眠直到接收到更多任务。
  • 仅当调用栈为空(即没有正在进行的任务)时,事件循环才会执行事件队列中的任务。
  • 事件循环允许我们使用回调和promise。
  • 事件循环从最早的(oldest first)任务开始执行任务。

Thread Pool 线程池

线程池为我们提供了 4 个独立的线程。事件循环会将繁重的任务卸载到线程池,这是自动的。线程池负责处理繁重的任务,例如

  • 件访问
  • 密码学相关的东西
  • 缓存密码
  • 文件压缩
  • DNS 查找

其他库

除了上述主要组件之外,Node.js 架构中还使用以下库来实现其他目的

  • HTP Parser — parsing HTTP
  • C-ARES — DNS queries
  • OpenSSL — cryptography
  • Zlib — file compression

Node.js 架构流程

  1. 客户端向服务器发送请求。请求可以是阻塞的或非阻塞的。
  2. Node.js 检索传入请求并将其添加到事件队列event queue中。
  3. 事件队列中将每个请求将 一 一 传递到事件循环。
  4. 事件循环检查请求是否足够小,可以在其自身中执行,否则将请求传递给线程循环
  5. 当线程池收到请求时,它会执行该请求并将响应再次传递给事件循环。

Node.js 架构的优点

  • 处理多个并发客户端请求既快速又简单
  • 无需创建太多线程
  • 需要更少的资源和内存

了解宏任务与微任务

考虑下面的代码(

setTimeout(() => {
    while (true) {
        console.log("a");
    }
}, 1000);

setTimeout(() => {
    while (true) {
        console.log("b");
    }
}, 1000);

这里,如果你运行这个程序,你在屏幕上遇到的唯一内容将是“a”。这是因为只要还有可用的指令,NodeJS 解释器就会继续执行当前的回调。

一旦主代码中的所有指令执行完毕,NodeJS 运行时环境就会开始调用回调函数。您还可以将您编写的主要代码视为默认情况下作为回调调用。在上面的例子中,第一个setTimeout是使用提供的回调函数执行的,第二个setTimeout是使用提供的回调函数执行的。 1 秒后,它开始发送“a”。您永远不会看到“b”,因为一旦调用第一个回调,它就会以 while 循环永远控制主线程!因此,第二个回调永远不会被调用

虽然你写了 1000 ms后回调输出b,但永远没有机会了

在这里插入图片描述


原文连接:Nodejs Architecture

Understanding Concurrency, Parallelism and JS

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

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

相关文章

对于《穿越火线》和《欢乐升级》游戏的理解

对于《穿越火线》的理解与感受 《穿越火线》(CrossFire)是一款承载了许多玩家青春记忆的经典FPS游戏。在初次接触这款游戏时,它给我的第一感觉是紧张刺激且极具沉浸感。无论是团队竞技的快节奏对抗,还是爆破模式中步步为营的策略…

Vite快速构建Vue教程

步骤 1: 初始化项目目录 创建一个名为 projects 的文件夹,作为存放所有 Vite 项目的根目录。这个文件夹将容纳多个独立的 Vite 项目。 步骤 2: 创建 Vite 项目 右键点击 projects 文件夹并选择“在此处打开终端”或使用您偏好的代码编辑器(如 VSCode&…

springboot429校运会管理系统(论文+源码)_kaic

摘 要 传统办法管理信息首先需要花费的时间比较多,其次数据出错率比较高,而且对错误的数据进行更改也比较困难,最后,检索数据费事费力。因此,在计算机上安装校运会管理系统软件来发挥其高效地信息处理的作用&#xff…

深度学习实验十四 循环神经网络(1)——测试简单循环网络的记忆能力和梯度爆炸实验

目录 一、数据集构建 1.1数据集的构建函数 1.2加载数据集并划分 1.3 构建Dataset类 二、模型构建 2.1嵌入层 2.2SRN层 2.3模型汇总 三、模型训练 3.1 训练指定长度的数字预测模型 3.2 损失曲线展示 四、模型评价 五、修改 附完整可运行代码 实验大体步骤&#x…

SQL去重查询C++ 中面向对象编程如何实现数据隐藏?C++ 中面向对象编程如何处理异常?Pimpl模式

SQL2 查询多列 select device_id,gender,age,university from user_profile; SQL3 查询结果去重 select distinct university from user_profile; select university from user_profile group by university; C 中面向对象编程如何实现数据隐藏? 使用访问控制修饰…

基于物联网的 AI 智能送药车与自维护基站系统研究

一、引言 (一)研究背景 随着科技的飞速发展,物联网技术在各个领域都展现出了巨大的潜力。在医疗领域,物联网技术的应用为提高医疗服务的效率和质量带来了新的机遇。其中,基于物联网的 AI 智能送药车与自维护基站系统…

sentinel 限流保护-笔记

本文属于b站图灵课堂springcloud笔记系列。讲的好还不要钱,值得推荐。 为什么要引入限流组件? 在微服务环境下,服务之间存在复杂的调用关系,单个服务的故障或过载可能会迅速影响到整个系统,导致服务雪崩效应。流控组件…

鸿蒙NEXT开发案例:颜文字搜索器

【引言】 本文将介绍一个名为“颜文字搜索器”的开发案例,该应用是基于鸿蒙NEXT平台构建的,旨在帮助用户快速查找和使用各种风格的表情符号。通过本案例的学习,读者可以了解如何在鸿蒙平台上进行数据处理、UI设计以及交互逻辑的实现。 【环…

【IntelliJ IDEA 集成工具】TalkX - AI编程助手

前言 在数字化时代,技术的迅猛发展给软件开发者带来了更多的挑战和机遇。为了提高技术开发群体在繁多项目中的编码效率和质量,他们需要一个强大而专业的工具来辅助开发过程,而正是为了满足这一需求,TalkX 应运而生。 一、概述 1…

python学opencv|读取图像(十二)BGR图像转HSV图像

【1】引言 前述已经学习了opencv中图像BGR相关知识,文章链接包括且不限于下述: python学opencv|读取图像(六)读取图像像素RGB值_opencv读取灰度图-CSDN博客 python学opencv|读取图像(七)抓取像素数据顺利…

Linux(网络协议和管理)

后面也会持续更新,学到新东西会在其中补充。 建议按顺序食用,欢迎批评或者交流! 缺什么东西欢迎评论!我都会及时修改的! 在这里真的很感谢这位老师的教学视频让迷茫的我找到了很好的学习视频 王晓春老师的个人空间…

代码随想录训练营第十七天| 654.最大二叉树 617.合并二叉树 700.二叉搜索树中的搜索 98.验证二叉搜索树

654.最大二叉树 题目链接/文章讲解: 代码随想录 视频讲解:又是构造二叉树,又有很多坑!| LeetCode:654.最大二叉树_哔哩哔哩_bilibili 创建一个根节点,其值为 nums 中的最大值。递归地在最大值 左边 的 子…

ISP(Image Signal Processor)——HDR技术总结

传统多帧融合技术 拍摄一系列不同曝光时长的图像帧(LDR),然后使用融合算法进行融合成HDR图像。 融合算法可以分为两种 基于照度图估计的融合 基于照度估计需要拟合相机响应函数,详细可以参考如下论文: Recovering H…

【理想汽车中科院】基于模仿学习的端到端自动驾驶数据缩放规律

论文: https://arxiv.org/pdf/2412.02689 项目: https://github.com/ucaszyp/Driving-Scaling-Law 0. 摘要 端到端自动驾驶范式因其可扩展性而最近吸引了大量关注。然而,现有方法受到现实世界数据规模有限的制约,这阻碍了对端到端自动驾驶相关扩展规律…

程序的调试

一名优秀的程序员也是一名出色的侦探,每一次调试都是尝试破案的过程 前言 一、什么是调试? 二、调试 1.调试是什么 2.基本步骤 三、调试注意事项 1.怎么写出易于调试的代码 2.常见错误 总结 前言 主要是怎么调试,调试的注意事项&#xff0c…

Linux内核移植之内核简介

学到本章节,大家应该对Linux操作系统都有了一定的了解,但可能还不知道我们拿到手的内核源码都经历了什么。 linux有一个庞大的开源社区,每个人都可以向开源社区提交代码。由于linux内核十分庞大所以每个模块都有对应的维护人员。维护人员的工…

2024年鄂州初级、中级职称公示了

本次鄂州市工程、中职教师、技工学校教师、档案、农业、新闻、艺术、群文、文博等专业中级和初级职称公示了,通过共有371人,公示时间为2024年12月9日至2024年12月13日。 本次公示工程类中级职称人员有210人通过评审,助理职称有35人通过评审。…

node_modules文件夹删除失败解决办法

在前端开发过程中,node_modules 文件夹是一个必不可少的组成部分,里面存放着项目所需的各种依赖包。然而,随着项目的发展,node_modules 文件夹可能会变得异常庞大,甚至有时需要删除它来解决一些依赖冲突或清理空间。但…

【合作原创】使用Termux搭建可以使用的生产力环境(六)

前言 在上一篇【合作原创】使用Termux搭建可以使用的生产力环境(五)-CSDN博客我们讲到了如何美化xfce4桌面,达到类似于Windows的效果,这一篇将继续在上一篇桌面的基础上给我们的系统装上必要的软件,让它做到真正可以使…

40 list类 模拟实现

目录 一、list类简介 (一)概念 (二)list与string和vector的区别 二、list类使用 (一)构造函数 (二)迭代器 (三)list capacity (四&#x…