学Node.js之前,哪些是我们必须知道的? —— 学不会算我输

简介: 很多同学都以为Node.js是一门独立的语言,这是大家的一个误区。

Node.js 是什么?



很多同学都以为Node.js是一门独立的语言,这是大家的一个误区。


Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境,让JavaScript 运行在服务端的开发平台。


实际上它是对Google Chrome V8引擎进行了封装,它主要用于创建快速的、可扩展的网络应用。


使用了一个事件驱动、非阻塞式 I/O 的模型,使其变得轻微和高效,非常适合构建运行在分布式设备的数据密集型实时应用。

1.png

Node.js 能做些什么?



JavaScript做客户端,Node为服务端而生

异步方式,适用于高并发(处理并行访问)

使用 JavaScript 作为服务器端脚本语言,可以消除一些与浏览器端 js 脚本的冲突

可以发挥 JavaScript 动态编程的特性,在服务器与浏览器之间建立直接的动态程序

应用层来说,可以进行像PHP一样做动态网站开发和WEB应用开发


2.png

对于前端程序员来说,Node.js 意味着什么?



拓宽知识域

      前端的知识领域实际上是很广的,但是大部分人被局限在了业务上或某家公司里,因为业务不需要或者公司不用所以就不学。这是不对的,前端的趋势是在往服务端走,所以这是我们一定要接触的东西。


提高核心竞争力

       这一点就很明显了,现在市面上的前端程序员10个有6个不会Node,然而市场是需要这门技术的。


优先录取权

      相信这句话已经屡见不鲜了:有node开发经验优先。但凡是大厂招人或是高薪前端岗位基本都会有Node的要求。


同步式I/O和异步式I/O



1. 同步式I/O(阻塞式I/O)


当计算机调度线程进行I/O操作命令后,由于文件的读写或者网络通信需要较长的操作时间,操作系统为了充分利用cpu,此时会暂停到当前的I/O线程对CPU的控制(故又称同步式为阻塞式I/O),把cup资源然给其他的线程资源。


当I/O线程完成了操作时,此时操作系统会恢复此时的I/O线程,从而当前I/O线程重新获得了cup的的控制权,继续完成其他操作。


举个例子: A同学接到了B同学的一个要求,要帮B去做某件事。这时候C老师和A同学说,你去帮我去做xxx事情,这个事情比较急。这个时候A同学不得不放下B同学的事情(停止当前线程),先去处理C老师交代的事情(开启一个新线程)。做完C老师交代的事情之后,又开始帮忙做B同学的事情。


代码案例(demo.js):

var fs   = require("fs");
// readFileSync表示同步读取
var data = fs.readFileSync("./store.js","utf-8");
console.log(data);
console.log("获取结束");

store.js是与demo.js同级的文件,通过同步请求可以拿过来,看到的结果是:

3.png

这就是典型的同步式,必须要等到文件读取完才会往下执行打印的操作。


2. 异步式I/O(非阻塞式I/O)


针对所有I/O操作不采用阻塞策略,当线程遇到I/O操作时,不会以阻塞的方式等待I/O操作的完成或数据的返回,而只是讲IO请求发送给操作系统,继续执行下一条语。


当操作系统完成IO操作时,以事件的形式通知执行IO操作的线程,线程会在特定时候处理这个事件,为了 处理异步IO,线程必须有事件循环,不断的检查有没有未处理的事件,依次予以处理。

var fs  = require("fs");
// 默认是采用异步式I/O
fs.readFile('./store.js','utf-8',function(err,data){
    if(err){
        console.log(err);
    }else{
        console.log(data);
    }
})
console.log("获取结束");

执行结果如下:4.png

看图就能知道,现在不用再等到文件读取完毕再执行打印了,这就是异步式。


3. 同步式I/O和异步式I/O的区别


异步式: 一个线程永远在执行计算操作,这个线程所使用的CPU核心利用率永远是100%,IO以事件的方式通知。

同步式: 多线程往往能提高系统吞吐量,因为一个线程阻塞还有其他线程在工作,多线程可以让CPU资源不被阻塞中的线程浪费。


吞吐量:  指于一通讯通道上单位时间能成功传递的平均资料量,简单的说就是表示系统能处理的多快。比如地铁站一个小时最大能允许多少人出入,这个也被称之为“吞吐量”。


这样就很明显虽然同步式的效率就不如异步式。


5.png

FAQ:

调度:简单来说就是指定两个参数:工作,触发器。举个例子:我十分钟后坐飞机,坐飞机是工作,十分钟就是触发器。

吞吐量:同步式是通过开辟多线程来提高吞吐量,异步式通过不断的请求来提高吞吐量。

CPU利用:同步式是通过对事件片的分割和现成的调度利用CPU,异步式是通过划分功能来利用CPU(有一个功能求开始请求)。

内存轨迹:内存轨迹大指的是开辟了多个线程,内存的变化就比较大;数据局部性是说数据比较散乱,线程可以没有联系,所以数据就比较散乱



目录
相关文章
|
5天前
|
数据采集 人工智能 自然语言处理
3分钟采集134篇AI文章!深度解析如何通过云无影AgentBay实现25倍并发 + LlamaIndex智能推荐
结合阿里云无影 AgentBay 云端并发采集与 LlamaIndex 智能分析,3分钟高效抓取134篇 AI Agent 文章,实现 AI 推荐、智能问答与知识沉淀,打造从数据获取到价值提炼的完整闭环。
385 93
|
6天前
|
域名解析 人工智能
【实操攻略】手把手教学,免费领取.CN域名
即日起至2025年12月31日,购买万小智AI建站或云·企业官网,每单可免费领1个.CN域名首年!跟我了解领取攻略吧~
|
5天前
|
SQL 人工智能 自然语言处理
Geo优化SOP标准化:于磊老师的“人性化Geo”体系如何助力企业获客提效46%
随着生成式AI的普及,Geo优化(Generative Engine Optimization)已成为企业获客的新战场。然而,缺乏标准化流程(Geo优化sop)导致优化效果参差不齐。本文将深入探讨Geo专家于磊老师提出的“人性化Geo”优化体系,并展示Geo优化sop标准化如何帮助企业实现获客效率提升46%的惊人效果,为企业在AI时代构建稳定的流量护城河。
390 156
Geo优化SOP标准化:于磊老师的“人性化Geo”体系如何助力企业获客提效46%
|
5天前
|
数据采集 缓存 数据可视化
Android 无侵入式数据采集:从手动埋点到字节码插桩的演进之路
本文深入探讨Android无侵入式埋点技术,通过AOP与字节码插桩(如ASM)实现数据采集自动化,彻底解耦业务代码与埋点逻辑。涵盖页面浏览、点击事件自动追踪及注解驱动的半自动化方案,提升数据质量与研发效率,助力团队迈向高效、稳定的智能化埋点体系。(238字)
270 158
|
13天前
|
机器人 API 调度
基于 DMS Dify+Notebook+Airflow 实现 Agent 的一站式开发
本文提出“DMS Dify + Notebook + Airflow”三位一体架构,解决 Dify 在代码执行与定时调度上的局限。通过 Notebook 扩展 Python 环境,Airflow实现任务调度,构建可扩展、可运维的企业级智能 Agent 系统,提升大模型应用的工程化能力。