node - process

进程

  1. 程序的实例就是进程
  2. 程序CPU上执行的活动叫做 进程
  3. 进程可以创建进程 被创建的是子进程,主进程关闭所有子进程也会关闭

CPU

单核CPU靠在不同的进程中切换达到多程序并发执行

  1. 多个程序在宏观上并行,微观上串行
  2. 每个进程会出现[执行 - 暂停 - 执行]的规律
  3. 多个进程之前会出现抢资源的现象(如打印机)
进程的两个状态
  1. 运行态
  2. 非运行态
    在这里插入图片描述

程序开始执行进程 由 CPU做分配暂停的处理

在这里插入图片描述

阻塞

如果A在等待CPU资源,而B在等待I/O完成(如文件读取) 这个时候将CPU资源分配给了B,B就会形成阻塞进程
因此,分派程序只会把CPU分配给非阻塞进程

CPU的轮询 - - 防止阻塞

在这里插入图片描述

线程 - 进程是他的容器、CPU里执行和调度的 最小单元

如果线程是车间的话,那线程就是车间里面的流水线

  • 引入的原因 : 进程的创建、切换、销毁太消耗CPU时间 - 占CPU资源

  • 进程的第一个线程叫做初始化线程

子进程 VS 线程

一般在node里是直接操作进程效率更高

child_process - 用于新建子进程

使用目的

  1. 子进程的运行结果会储存在系统缓存中(最大200kb)
  2. 等到子进程运行结束以后,主进程再用回调函数读取子进程的运行结果

通过操作子进程达到最优缓存使用
node操作进程的四个api

  1. exec
  2. execFile
  3. spawn
  4. fork
child_process.exec(command[,options][,callback])

exec
漏洞:

  • 如果cmd被注入,可能会执行意外的代码
  • 推荐使用execFile
// 配合流使用案例
var exec = require('child_process').exec;
var child = exec('ls -l');
child.stdout.on('data', function(data) {
console.log('stdout: ' + data);
});
child.stderr.on('data', function(data) {
console.log('stdout: ' + data);
});
child.on('close', function(code) {
console.log('closing code: ' + code);
});
child_process.execFile(file[, args][, options][, callback])

execFile

  • 执行特定的程序
  • 命令行的参数要用数组形式传入,无法注入
  • 同步的版本:execFileSync
child_process.spawn(command[, args][, options])

spawn

  • 能用spawn就不要用execFile
  • 用法与execFile类似
  • 没有毁掉函数,只能通过流时间获取结果
  • 没有最大200K的限制(因为是流)
// spawn的用法示例
var child_process = require('child_process');
var { spawn } = child_process;
const userInput = "."

const streams = spawn("ls",["-la",userInput],{
	cwd: 'C:\\',
	env: {NODE_ENV: 'development'}
})

stream.stdout.on('data',(chunk)=>{
	console.log(chunk.toString())
})
child_process.fork(modulePath[, args][, options])

fork

  • 创建一个子进程,执行Node脚本
  • fork(’./child.js’)相当于spawn(‘node’,[’./child.js’])
  • 能用fork就不要用spawn

特点

  1. 通过message事件,用于父子通信
  2. 通过send方法 父子传值
// 这是child.js
process.on('message', function(m) { 
console.log('子进程得到的爸爸的:', m); // 子进程得到的爸爸的: { hello: 'world' }
}); 
process.send({ foo: 'bar' });
// 监听child.js
var n = child_process.fork('./child.js');
n.on('message', function(m) {
console.log('父进程得到了child:', m); // 父进程得到了child: { foo: 'bar' }
});
n.send({ hello: 'world' }); // 给子进程传值

node的工作线程

worker_threads 工作线程

来自官方文档对worker_threads的描述:
工作线程对于执行 CPU 密集型的 JavaScript 操作很有用。 它们对 I/O 密集型的工作帮助不大。 Node.js 内置的异步 I/O 操作比工作线程更高效

  • new Worker效率不够高
  • 它是在v10.5.0版本加入node,在v11.7.0版本之前需要 – experimental-worker 开启
  • 而child_process.exec在V0.1.90就加入了Node了
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Supernova_gu

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值