Node.js笔记之process模块解读


Posted in Javascript onMay 31, 2018

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

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

资源使用

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

内存

process.memoryUsage())

{ rss: 21848064,
 heapTotal: 7159808,
 heapUsed: 4431688,
 external: 8224 
 }

rss(常驻内存)的组成见下图

Node.js笔记之process模块解读

code segment对应当前运行的代码

external对应的是C++对象(与V8管理的JS对象绑定)的占用的内存,比如Buffer的使用

Buffer.allocUnsafe(1024 * 1024 * 1000);
console.log(process.memoryUsage());

{ rss: 22052864,
 heapTotal: 6635520,
 heapUsed: 4161376,
 external: 1048584224 }

cpu

const startUsage = process.cpuUsage();
console.log(startUsage);

const now = Date.now();
while (Date.now() - now < 500);

console.log(process.cpuUsage());
console.log(process.cpuUsage(startUsage)); //相对时间

// { user: 59459, system: 18966 }
// { user: 558135, system: 22312 }
// { user: 498432, system: 3333 }

user对应用户时间,system代表系统时间

运行环境

运行环境指此进程运行的宿主环境包括运行目录、node环境、CPU架构、用户环境、系统平台

运行目录

const startUsage = process.cpuUsage();
console.log(startUsage);

const now = Date.now();
while (Date.now() - now < 500);

console.log(process.cpuUsage());
console.log(process.cpuUsage(startUsage)); //相对时间

// { user: 59459, system: 18966 }
// { user: 558135, system: 22312 }
// { user: 498432, system: 3333 }

node环境

console.log(process.version)

// v9.1.0

如果不仅仅希望获得node的版本信息,还希望v8、zlib、libuv版本等信息的话就需要使用process.versions了

console.log(process.versions);
{ 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',
 nghttp2: '1.25.0',
 openssl: '1.0.2m',
 icu: '59.1',
 unicode: '9.0',
 cldr: '31.0.1',
 tz: '2017b' }

cpu架构

console.log(`This processor architecture is ${process.arch}`);

// This processor architecture is x64

支持的值包括:'arm', 'arm64', 'ia32', 'mips', 'mipsel', 'ppc', 'ppc64', 's390', 's390x', 'x32' 'x64'

用户环境

console.log(process.env.NODE_ENV); // dev

NODE_ENV=dev node b.js

除了启动时的自定义信息之外,process.env还可以获得其他的用户环境信息(比如PATH、SHELL、HOME等),感兴趣的可以自己打印一下试试

系统平台

console.log(`This platform is ${process.platform}`);

This platform is darwin

支持的系统平台包括:'aix' 'darwin' 'freebsd' 'linux' 'openbsd' 'sunos' 'win32'

android目前还处于试验阶段

运行状态

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

启动参数

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

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

console.log(process.argv)
console.log(process.argv0)
console.log(process.execArgv)

node --harmony b.js foo=bar --version

// 输出结果
[ '/Users/xiji/.nvm/versions/node/v9.1.0/bin/node',
 '/Users/xiji/workspace/learn/node-basic/process/b.js',
 'foo=bar',
 '--version' ]
node
[ '--harmony' ]

执行目录

console.log(process.execPath);

// /Users/xxxx/.nvm/versions/node/v9.1.0/bin/node

运行时间

var date = new Date();
while(new Date() - date < 500) {}
console.log(process.uptime()); // 0.569

主文件

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

//a.js
console.log(`module A: ${process.mainModule === module}`);

//b.js
require('./a');
console.log(`module B: ${process.mainModule === module}`);

node b.js
// 输出
module A: false
module B: true

PID信息

console.log(`This process is pid ${process.pid}`); //This process is pid 12554

监听事件

常用的事件有beforeExit、exit、uncaughtException、message

beforeExit与exit的区别有两方面:

  1. beforeExit里面可以执行异步代码、exit只能是同步代
  2. 码手动调用process.exit()或者触发uncaptException导致进程退出不会触发beforeExit事件、exit事件会触发。

因此下面的代码console都不会被执行

process.on('beforeExit', function(code) {
 console.log('before exit: '+ code);
});
process.on('exit', function(code) {
 setTimeout(function() {
  console.log('exit: ' + code);
 }, 0);
});
a.b();

当异常一直没有被捕获处理的话,最后就会触发'uncaughtException'事件。默认情况下,Node.js会打印堆栈信息到stderr然后退出进程。不要试图阻止uncaughtException退出进程,因此此时程序的状态可能已经不稳定了,建议的方式是及时捕获处理代码中的错误,uncaughtException里面只做一些清理工作(可以执行异步代码)。

注意:node的9.3版本增加了process.setUncaughtExceptionCaptureCallback方法

当process.setUncaughtExceptionCaptureCallback(fn)指定了监听函数的时候,uncaughtException事件将会不再被触发。

process.on('uncaughtException', function() {
 console.log('uncaught listener');
});

process.setUncaughtExceptionCaptureCallback(function() {
 console.log('uncaught fn');
});

a.b();
// uncaught fn

message适用于父子进程之间发送消息,关于如何创建父子进程会放在child_process模块中进行。

调度任务

process.nextTick(fn)

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

Node.js笔记之process模块解读

发出警告

process.emitWarning('Something warning happened!', {
 code: 'MY_WARNING',
 type: 'XXXX'
});

// (node:14771) [MY_WARNING] XXXX: Something warning happened!

当type为DeprecationWarning时,可以通过命令行选项施加影响

  1. --throw-deprecation 会抛出异常
  2. --no-deprecation 不输出DeprecationWarning
  3. --trace-deprecation 打印详细堆栈信息
process.emitWarning('Something warning happened!', {
 type: 'DeprecationWarning'
});
console.log(4);

node --throw-deprecation index.js
node --no-deprecation index.js
node --trace-deprecation index.js

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
比较简单的异步加载JS文件的代码
Jul 18 Javascript
qTip 基于JQuery的Tooltip插件[兼容性好]
Sep 01 Javascript
js 链式延迟执行DOME
Jan 04 Javascript
javascript(js)的小数点乘法除法问题详解
Mar 07 Javascript
javascript中的循环语句for语句深入理解
Apr 04 Javascript
jQuery对指定元素中指定字符串进行替换的方法
Mar 17 Javascript
js+css实现select的美化效果
Mar 24 Javascript
jQuery实现下拉加载功能实例代码
Apr 01 Javascript
jQuery ajax实现省市县三级联动
Mar 07 Javascript
Angularjs单选框相关的示例代码
Aug 17 Javascript
详解Javascript中new()到底做了些什么?
Mar 29 Javascript
Vue-router 切换组件页面时进入进出动画方法
Sep 01 Javascript
Vue组件中prop属性使用说明实例代码详解
May 31 #Javascript
用JS实现根据当前时间随机生成流水号或者订单号
May 31 #Javascript
Vue2 轮播图slide组件实例代码
May 31 #Javascript
vue2.0+vuex+localStorage代办事项应用实现详解
May 31 #Javascript
JavaScript 中的12种循环遍历方法【总结】
May 31 #Javascript
Vue 让元素抖动/摆动起来的实现代码
May 31 #Javascript
angular2路由之routerLinkActive指令【推荐】
May 30 #Javascript
You might like
用Flash图形化数据(一)
2006/10/09 PHP
php 函数中使用static的说明
2012/06/01 PHP
用jQuery实现检测浏览器及版本的脚本代码
2008/01/22 Javascript
jquery attr 设定src中含有&amp;(宏)符号问题的解决方法
2011/07/26 Javascript
js函数调用常用方法详解
2012/12/03 Javascript
Javascript操作URL函数修改版
2013/11/07 Javascript
用javascript为页面添加天气显示实现思路及代码
2013/12/02 Javascript
JQuery 给元素绑定click事件多次执行的解决方法
2014/09/09 Javascript
jQuery异步获取json数据方法汇总
2014/12/22 Javascript
JavaScript异步加载浅析
2014/12/28 Javascript
JavaScript中常见获取元素的方法汇总
2015/03/04 Javascript
javascript省市区三级联动下拉框菜单实例演示
2015/11/29 Javascript
JS面试题---关于算法台阶的问题
2016/07/26 Javascript
XMLHttpRequest Level 2 使用指南
2016/08/26 Javascript
浅谈js中同名函数和同名变量的执行问题
2017/02/12 Javascript
微信小程序的日期选择器的实例详解
2017/09/29 Javascript
js实现随机点名系统(实例讲解)
2017/10/18 Javascript
Vue入门之数据绑定(小结)
2018/01/08 Javascript
基于vue2.0动态组件及render详解
2018/03/17 Javascript
浅谈Vue数据响应思路之数组
2018/11/06 Javascript
vuex入门最详细整理
2020/03/04 Javascript
[03:24]DOTA2超级联赛专访hao 大翻盘就是逆袭
2013/05/24 DOTA
[01:01:52]完美世界DOTA2联赛PWL S2 GXR vs Magma 第二场 11.25
2020/11/26 DOTA
Python实现从百度API获取天气的方法
2015/03/11 Python
Python设计模式之MVC模式简单示例
2018/01/10 Python
numpy 进行数组拼接,分别在行和列上合并的实例
2018/05/08 Python
python3 中的字符串(单引号、双引号、三引号)以及字符串与数字的运算
2019/07/18 Python
Windows下实现将Pascal VOC转化为TFRecords
2020/02/17 Python
查找适用于matplotlib的中文字体名称与实际文件名对应关系的方法
2021/01/05 Python
Python爬虫自动化爬取b站实时弹幕实例方法
2021/01/26 Python
Tomcat的缺省是多少,怎么修改
2014/04/09 面试题
学生自我鉴定范文
2013/10/04 职场文书
财务担保书范文
2014/04/02 职场文书
连锁超市项目计划书
2014/09/15 职场文书
公务员年度考核个人总结
2015/02/12 职场文书
2015年度优秀员工获奖感言
2015/07/31 职场文书