Node 进程

简介: 在操作系统中,对进程的解释:进程是一个具有一定独立功能的程序在一个数据集上的一次动态执行的过程,是操作系统进行资源分配和调度的一个独立单位,是应用程序运行的载体。- 是应用程序的一次运行过程(动态概念)- 是系统分配和调度资源的基本单位(进程是一般由程序、数据集合和进程控制块三部分组成)- 每个进程有自己独立的空间地址,数据栈(各进程间数据不共享,可通过其他方式进行通信)进程一般有初始态,执行态,等待状态,就绪状态,终止状态五种状态

进程

在操作系统中,对进程的解释:进程是一个具有一定独立功能的程序在一个数据集上的一次动态执行的过程,是操作系统进行资源分配和调度的一个独立单位,是应用程序运行的载体。

  • 是应用程序的一次运行过程(动态概念)
  • 是系统分配和调度资源的基本单位(进程是一般由程序、数据集合和进程控制块三部分组成)
  • 每个进程有自己独立的空间地址,数据栈(各进程间数据不共享,可通过其他方式进行通信)进程一般有初始态,执行态,等待状态,就绪状态,终止状态五种状态

线程

线程是程序执行中一个单一的顺序控制流程,是程序执行流的最小单元,是处理器调度和分派的基本单位。

  • 任务调度和执行的最小单位
  • 一个进程中代码单一执行路线

进程和线程区别

线程是程序执行的最小单位,进程是操作系统分配资源的最小单位一个进程由一个或多个线程组成,线程是一个进程中代码的不同执行路线进程间相互独立,但同一进程下各线程之间共享程序的内存空间线程上下文切换比进程上下文切换要快

node中进程

node是单线程的,即一个进程只开一个线程node

真的单线程吗?

Node 虽然是单线程,但是其底层是多线程的。事件循环中,libuv库从事件队列中取出任务再分配给不同的线程进行处理。现在硬件条件没有以前那么落后,如果只使用单线程进行操作,则会浪费资源。所以,为了实现多进程处理,充分发挥多核CPU的优势,Node中提供了child_process模块和cluster模块。

  • child_process模块用于开启多个子进程,子进程中运行不同的命令或执行node.js模块文件、可执行文件
  • Cluster模块,集群模块,用于实现在Node.js应用程序中开启多个子进程,每个子进程中运行一个Node.js应用程序副本的处理

child_process模块

  • child_process.spawn():适用于返回大量数据,例如图像处理,二进制数据处理。
  • child_process.exec():适用于小量数据,maxBuffer 默认值为 200 * 1024 超出这个默认值将会导致程序崩溃,数据量过大可采用 spawn。
  • child_process.execFile():类似 child_process.exec(),区别是不能通过 shell 来执行,不支持像 I/O 重定向和文件查找这样的行为
  • child_process.fork(): 衍生新的进程,进程之间是相互独立的,每个进程都有自己的 V8 实例、内存,系统资源是有限的,不建议衍生太多的子进程出来,通常根据系统* CPU 核心数设置。

cluster模块

  • cluster.fork([env]) 开启子进程,子进程中创建一个Node.js应用程序的实例
  • isMaster属性和isWorker属性用于判断是运行在主进程中,还是运行在子进程中
  • Workers属性用于获取所有子进程中运行的worker对象

扩展一下,多线程之间如何通信?

进程间的通信

四种:

  • 消息传递(管道、FIFO、消息队列)
  • 信号量(互斥量、条件变量、读写锁)
  • 共享内存(匿名、命名)
  • 远程过程调用

进程间的通信不仅在node中会遇到,其实在其他语言都会遇到的,当然在面试中也是必提问的问题吧。

很多内容都可以进行深入扩展讨论

目录
相关文章
|
负载均衡 JavaScript 算法
Node.js 多进程的概念、原理、优势以及如何使用多进程来提高应用程序的性能和可伸缩性
Node.js 多进程的概念、原理、优势以及如何使用多进程来提高应用程序的性能和可伸缩性
305 1
|
缓存 JavaScript Unix
Node.js 多进程
10月更文挑战第8天
135 0
|
JavaScript Windows
NodeJs——如何获取Windows电脑指定应用进程信息
NodeJs——如何获取Windows电脑指定应用进程信息
309 0
|
JavaScript 前端开发
nodejs process进程
nodejs process进程
171 0
|
JavaScript 前端开发 Shell
深入Node.js的进程与子进程:从文档到实践
深入Node.js的进程与子进程:从文档到实践
|
消息中间件 监控 JavaScript
Node.js中的进程管理:child_process模块与进程管理
【4月更文挑战第30天】Node.js的`child_process`模块用于创建子进程,支持执行系统命令、运行脚本和进程间通信。主要方法包括:`exec`(执行命令,适合简单任务)、`execFile`(安全执行文件)、`spawn`(实时通信,处理大量数据)和`fork`(创建Node.js子进程,支持IPC)。有效的进程管理策略涉及限制并发进程、处理错误和退出事件、使用流通信、谨慎使用IPC以及监控和日志记录,以确保应用的稳定性和性能。
node子进程(Child Process)获取硬盘分区
node子进程(Child Process)获取硬盘分区
148 0
|
8月前
|
Linux 数据库 Perl
【YashanDB 知识库】如何避免 yasdb 进程被 Linux OOM Killer 杀掉
本文来自YashanDB官网,探讨Linux系统中OOM Killer对数据库服务器的影响及解决方法。当内存接近耗尽时,OOM Killer会杀死占用最多内存的进程,这可能导致数据库主进程被误杀。为避免此问题,可采取两种方法:一是在OS层面关闭OOM Killer,通过修改`/etc/sysctl.conf`文件并重启生效;二是豁免数据库进程,由数据库实例用户借助`sudo`权限调整`oom_score_adj`值。这些措施有助于保护数据库进程免受系统内存管理机制的影响。
|
8月前
|
Linux Shell
Linux 进程前台后台切换与作业控制
进程前台/后台切换及作业控制简介: 在 Shell 中,启动的程序默认为前台进程,会占用终端直到执行完毕。例如,执行 `./shella.sh` 时,终端会被占用。为避免不便,可将命令放到后台运行,如 `./shella.sh &`,此时终端命令行立即返回,可继续输入其他命令。 常用作业控制命令: - `fg %1`:将后台作业切换到前台。 - `Ctrl + Z`:暂停前台作业并放到后台。 - `bg %1`:让暂停的后台作业继续执行。 - `kill %1`:终止后台作业。 优先级调整:
536 5

热门文章

最新文章