手机版

Node.js笔记之过程模块解读

时间:2021-08-31 来源:互联网 编辑:宝哥软件园 浏览:

过程存在于全局对象上,不需要使用需要()加载即可使用,过程模块主要做两方面的事情

读:获取进程信息(资源使用、运行环境、运行状态)写:执行进程操作(监听事件、调度任务、发出警告)资源使用资源使用

指运行此进程所消耗的机器资源。例如内存、cpu

内存

过程。memoryusage()){ RSS : 21848064,heapTotal: 7159808,heapUsed: 4431688,external: 8224 }rss(常驻内存)的组成见下图

代码段对应当前运行的代码

外部对应的是C对象(与V8管理的射流研究…对象绑定)的占用的内存,比如缓冲器的使用

缓冲区。alloconsafe(1024 * 1024 * 1000);控制台。日志(进程。memoryusage());{ rss: 22052864,heapTotal: 6635520,heapUsed: 4161376,external: 1048584224 }cpu

const startUsage=process。cpuusage();控制台。日志(开始使用);立即常量=日期。now();while (Date.now() -现在是500);控制台。日志(进程。cpuusage());控制台。日志(进程。cpuusage(startUsage));//相对时间//{ user: 59459,system3360 18966 }//{ user : 558135,system3360 22312 }/{ user 3360 498432,system: 3333 }用户对应用户时间,系统代表系统时间

运行环境

运行环境指此进程运行的宿主环境包括运行目录、节点环境、中央处理器架构、用户环境、系统平台

运行目录

const startUsage=process。cpuusage();控制台。日志(开始使用);立即常量=日期。now();while (Date.now() -现在是500);控制台。日志(进程。cpuusage());控制台。日志(进程。cpuusage(startUsage));//相对时间//{ user: 59459,system3360 18966 }//{ user : 558135,system3360 22312 }/{ user 3360 498432,system: 3333 }节点环境

控制台。日志(进程。版本)//v 9。1 .0如果不仅仅希望获得结节的版本信息,还希望v8、zlib、libuv版本等信息的话就需要使用流程。版本了

控制台。日志(进程。版本);{ http_parser: '2.7.0 ',node: '9.1.0 ',v8: '6.2.414.32-node.8 ',uv: '1.15.0 ',zlib: '1.2.11 ',ares: '1.13.0 ',modules: ' 59 ',nghttp 23360 ' 1。25 .' 0 ',打开SSL 333333330架构

console . log(` 0这个处理器架构是$ { process。arch } `);//这个处理器架构是x64支持的值包括:' arm ',' arm64 ',' ia32 ',' mips ',' mipsel ',' ppc ',' ppc64 ',' s390 ',' s390x ',' x32' 'x64 '

用户环境

控制台。日志(进程。ENV。NODE _ ENV);//devNODE_ENV=dev node b.js除了启动时的自定义信息之外,process.env还可以获得其他的用户环境信息(比如路径、外壳、家等),感兴趣的可以自己打印一下试试

系统平台

console . log(` 0这个平台是$ { process。platform } `);这个平台就是达尔文支持的系统平台包括:“AIX”“达尔文”“FreeBSD”“Linux”“openbsd”“sunos”“win32”

机器人目前还处于试验阶段

运行状态

运行状态指当前进程的运行相关的信息包括启动参数、执行目录、主文件、PID信息、运行时间

启动参数

获取启动参数有三个方法,execArgv获取Node.js的命令行选项(见官网文档)

参数获取非命令行选项的信息,argv0则获取argv[0]的值(略有差异)

控制台。日志(进程。argv)控制台。日志(进程。argv 0)控制台。日志(进程。execargv)节点- harmony b.js foo=bar - version//输出结果['/用户/西集/.nvm/版本/节点/v 9。1 .0/bin/node ','/Users/xiji/workspace/learn/node-basic/process/b . js ',' foo=bar ','- version' ]node[ ' - harmony' ]执行目录

控制台。日志(进程。exec路径);///用户/xxxx/.nvm/版本/节点/v 9。1 .0/bin/节点运行时间

var Date=新日期();而(新日期()-日期500){ }控制台。日志(进程。正常运行时间());//0.569主文件

除了require.main之外也可以通过process.mainModule来判断一个模块是否是主文件

//一个. js控制台。日志(`模块a : $ { process。main module===module } `);//b.jsrequire(' ./a ');控制台。日志(`模块b : $ { process。main module===module } `);节点b.js//输出模块A:脚手架模块B: truePID信息

console . log(` 0此进程是PID $ { process。PID } `);//这个过程是pid 12554监听事件

常用的事件有退出前、退出、取消交换异常、消息

退出前与出口的区别有两方面:

退出前里面可以执行异步代码、出口只能是同步代码手动调用process.exit()或者触发uncaptException导致进程退出不会触发退出前事件、出口事件会触发。因此下面的代码安慰都不会被执行

process.on('beforeExit ',函数(代码){控制台。日志('在退出3360之前'代码);});process.on('exit ',function(code){ setTimeout(function(){ console。日志'(退出3360 '代码);}, 0);});a . b();当异常一直没有被捕获处理的话,最后就会触发'未绘制异常'事件。默认情况下,Node.js会打印堆栈信息到标准错误然后退出进程。不要试图阻止无图表异常退出进程,因此此时程序的状态可能已经不稳定了,建议的方式是及时捕获处理代码中的错误,未绘制异常里面只做一些清理工作(可以执行异步代码)。

注意:节点的9.3版本增加了过程。setunasseexception capturecallback方法

当过程。setunssetexcepcapturecallback(fn)指定了监听函数的时候,未绘制异常事件将会不再被触发。

过程。on(' UncaptureException ',function(){ console。日志(“Uncapture侦听器”);});过程。setunkuntexception capturecallback(函数(){ console。日志('未捕获的fn ');});a . b();//未捕获的fnmessage适用于父子进程之间发送消息,关于如何创建父子进程会放在子进程模块中进行。

调度任务

process.nextTick(fn)

通过process.nextTick调度的任务是异步任务,事件循环是分阶段的,每个阶段执行特定的任务,而下一步的任务在阶段切换的时候就会执行,因此下一步会比setTimeout(fn,0)更快的执行,关于事件循环见下图,后面会做进一步详细的讲解

发出警告

process.emitWarning('发生了一些警告!',{ code: 'MY_WARNING ',键入: ' XXXX ' });//(节点:14771)[MY _ WARNING]xxxx :发生了一些警告!当类型为折旧警告时,可以通过命令行选项施加影响

扔弃会抛出异常-不-贬低不输出折旧警告-跟踪-折旧打印详细堆栈信息process.emitWarning('发生了一些警告!',{键入: ' DepretationWarning ' });控制台。日志(4);节点投掷防御指数。无防御指数。jsnode-trace-防御索引。射流研究…以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

版权声明:Node.js笔记之过程模块解读是由宝哥软件园云端程序自动收集整理而来。如果本文侵犯了你的权益,请联系本站底部QQ或者邮箱删除。