Node玩转多进程

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Node玩转多进程相关的知识,希望对你有一定的参考价值。

参考技术A Node的优势,擅长处理IO密集型应用,不要关心多线程带来的开辟内存的开销及上下文切换带来的开销。它带来的好处是:不用担心锁、线程同步问题,操作系统在调度的时候也会因为较少的上下文切换,可以很好的提高CPU的利用率。

Node基于事件驱动实现了高并发,但是随之而来的带来了一些问题。
问题一:如何保证应用程序的稳定性?
问题二:如何充分利用多核CPU?

应用程序的稳定性,对于所有的处理都共用同一个上下文环境,会影响应用程序的稳定性。
每个进程占有一个CPU,就可以充分利用多核CPU。Node的事件驱动已经解决的高并发量的问题。而多线程的只是用来充分利用多核CPU。

主从模式。主进程和工作进程,主进程不负责具体的业务处理,而是负责调度或者管理工作进程。

child_process模块可以创建多个子进程
四种创建子进程的方法
1.spawn()
启动一个子进程来执行命令
2.exec()
启动一个子进程来执行命令,有一个回调函数获知子进程的状况
3.execFile()
启动一个子进程来执行可执行文件,有一个回调函数获知子进程的状况
4.fork()
与spawn()类似,不同点在于它创建Node的子进程只需要指定要执行的javascript文件模块即可

父进程与子进程之间建立IPC通道
message 获取信息
send发送信息
在发送和获取两个阶段需要注意数据的序列化和反序列化

45天带你玩转Node(第二天)走进Node.js

45天带你玩转Node

粉丝要求博主系统的写一篇关于Node.js的学习资料,但其实我们的Node.js知识点并不少,所以博主为大家搭建了一个专栏,为了方便大家系统的学习Node.js,大家记得订阅哦!虽然我们的Node.js还很年轻,但是他也已经有了很高的地位,让我们尽情的畅游在Node.js的专栏中吧,希望通过此专栏我们能够系统的将Node.js学好,它将会成为我们的一大亮点,我们可以用这款前端中的后端语言让提升我们的价值与眼界,如今的他也已经成为面试官口中的高并发面试内容了,一起加油!

走进Node.js

V8 JavaScript 引擎

我们都知道⼏乎所有现代主流浏览器都全⾯⽀持了ECMAScript 5.1版标准,⽽JavaScript的标准是。那么我们就容易认为JavaScript是⼀种浏览器端的解释型编程脚本。那么脱离了浏览器,JavaScript还能够解释运⾏吗?答案是肯定的,也就是说脱离了浏览器,在特定环境下JavaScript还是能运⾏的。JavaScript向来以Web⽹页的脚本语⾔⽽著称,但现在也可以,例如或者。我们都知道⼏乎所有现代主流浏览器都全⾯⽀持了ECMAScript 5.1版标准,⽽JavaScript的标准是。那么我们就容易认为JavaScript是⼀种浏览器端的解释型编程脚本。那么脱离了浏览器,JavaScript还能够解释运⾏吗?
答案是肯定的,也就是说脱离了浏览器,在特定环境下JavaScript还是能运⾏的。JavaScript向来以Web⽹页的脚本语⾔⽽著称,但现在也可以,例如或者。本⽂就是基于NodeJS来进⾏探讨。

V8 是驱动 Google Chrome 的 JavaScript 引擎的名称。 这是在使用 Chrome 浏览时获取我们的 JavaScript 并执行它的东西。
V8 提供了 JavaScript 执行的运行时环境。 DOM 和其他 Web 平台 API 由浏览器提供。

很酷的是 JavaScript 引擎独立于它所在的浏览器。 这个关键特性促成了 Node.js 的兴起。 早在 2009 年,V8 就被选为驱动 Node.js 的引擎,随着 Node.js 的流行,V8 成为现在为大量使用 JavaScript 编写的服务器端代码提供驱动的引擎。

Node.js 生态系统非常庞大,这要归功于 V8,它还支持桌面应用程序,例如 Electron 等项目。

其他的JS引擎

  • Firefox 具有 SpiderMonkey
  • Safari 具有 JavaScriptCore(也称为 Nitro)
  • Edge 最初基于 Chakra,但最近使用 Chromium 和 V8 引擎重建。

还有许多其他的存在。

所有这些引擎都实现了 ECMA ES-262 标准,也称为 ECMAScript(JavaScript 使用的标准)。

追求性能

V8 是用 C++ 编写的,并且在不断改进。 它是可移植的,可以在 Mac、Windows、Linux 和其他几个系统上运行。

在此 V8 介绍中,我们将忽略 V8 的实现细节:它们可以在更权威的网站上找到(例如 V8 官方网站),它们经常会从根本上随着时间的推移而变化。

V8 一直在发展,就像周围的其他 JavaScript 引擎一样,以加速 Web 和 Node.js 生态系统。

在 web 上,性能竞赛已经持续了多年,我们(作为用户和开发人员)从这场竞争中受益匪浅,因为我们年复一年地获得更快、更优化的机器。

编译

JavaScript 通常被认为是一门解释型语言,但是现代的 JavaScript 引擎不再只是解释 JavaScript,它们会编译它。

这从 2009 年开始发生,当时 SpiderMonkey JavaScript 编译器被添加到 Firefox 3.5 中,所有人都遵循这个想法。

JavaScript 由 V8 在内部使用即时 (JIT) 编译以加快执行速度。

这可能看起来有悖常理,但自从 2004 年 Google 地图推出以来,JavaScript 已经从一门通常执行几十行代码的语言发展为在浏览器中运行数千到数十万行代码的完整应用程序。

我们的应用程序现在可以在浏览器中运行数小时,而不仅仅是一些表单验证规则或简单的脚本。

在这个新世界中,编译 JavaScript 非常有意义,因为虽然准备好 JavaScript 可能需要更多时间,但是一旦完成,它将比纯粹的解释型代码性能更高。

运行 Node.js 脚本

运行 Node.js 程序的常用方法是,运行全局可用的命令 node(安装 Node.js 之后)并且传入您要执行的文件的名称。

如果您的 Node.js 主应用程序文件是 app.js,则您可以通过键入以下来调用它:

node app.js

以上,你显式地告诉 shell 使用 node 运行你的脚本。 您也可以使用 “shebang” 行将此信息嵌入到 JavaScript 文件中。 “shebang” 是文件的第一行,它告诉操作系统使用哪个解释器来运行脚本。 以下是 JavaScript 的第一行

#!/usr/bin/node

以上,我们显式地给出了解释器的绝对路径。 并非所有操作系统的 bin 文件夹中都有 node,但都应该有 env。 您可以告诉操作系统使用 node 为参数运行 env:

#!/usr/bin/env node

// 你的代码

要使用 shebang,您的文件应该具有可执行权限。 您可以通过运行以下赋予 app.js 可执行权限:

chmod u+x app.js

当运行命令时,请确保您位于包含 app.js 文件的同一目录中。

总结

本篇文章大部分也都是一些按照官网总结的理论内容,主要就是让大家对Node.js有基本的了解,了解我们V8、了解我们的Node优势,下一节我们就为大家带来我们Node的实操内容了哦!!!我们下篇见。

本期推荐

随着网络技术的迅速发展,如何有效地提取并利用信息,以及如何有效地防止信息被爬取,已成为一个巨大的挑战。本书从零基础开始讲解,系统全面,案例丰富,注重实战,既适合Python程序员和爬虫爱好者阅读学习,也可以作为广大职业院校相关专业的教材或参考用书。础操作、图形处理基本操作、简单图形的绘制和对象的管理等内容。

面试法宝

很多伙伴找到我询问面试题,问我针对于前端有没有比较体系化的面试题总结,今天就给大家推荐这款面试法宝
点击链接直达

https://www.nowcoder.com/link/jihexinliang260

就是我们的牛客网,各大互联网大厂面试真题。从基础到入阶乃至原理刨析类面试题 应有尽有,赶快来装备自己吧!助你面试稳操胜券,solo全场面试官





以上是关于Node玩转多进程的主要内容,如果未能解决你的问题,请参考以下文章

带你玩转多进程编程

深入浅出Node.js - 玩转进程

玩转多线程

分布式软总线让阿里巴巴商家玩转多设备直播

玩转华为ENSP模拟器系列 | 配置OSPF多进程

基础入门_Python-进线协程.分分钟玩转multiprocessing多进程编程?