前言
我们在了解 Nodejs 的优势的时候,肯定会从 “单进程,单线程,异步非堵塞和事件驱动” 这几点开始发散讲述,特别是单进程单线程,这是它和 其他语言的 多进程 任务处理模型很大区别之处,但是这里恐怕并未彻底了解 单进程 和 单线程 在 Nodejs 中到底是如何工作的呢?
首先我们需要了解下什么是进程,什么是线程?这方便我们了解计算机任务处理模式。
进程是具有独立功能的程序在数据集上的一次动态执行过程,是操作系统进行资源分配和调度的一个独立单元,是应用程序运行的载体(来自维基百科)
由于进程切换需要保存相关的硬件现场,进程控制块等信息,所以系统开销较大(这点老生常谈的多进程缺点)。为了进一步提高系统的吞吐量,在同一进程执行的时候充分利用CPU资源,所以引入了线程的概念。
线程是操作系统调度执行的最小单位,它依附在进程中,共享同一进程的资源,不拥有或者只拥有少量的资源。
实操
在了解完概念之后,我们需要通过实际操作,来了解一个 Nodejs 程序在运行的时候进程和线程的使用情况。
实例一(不包含文件操作 I/O)
const http = require("http");
http
.createServer((req, res) => {
res.writeHead(200);
res.end("hello word");
})
.listen(8000);
console.log("process id", process.pid);
上面是一个非常简单的 Nodejs 后端服务代码,启动没做