Node.js笔记之process模块解读

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

读:获取进程信息(资源使用、运行环境、运行状态)

写:执行进程操作(监听事件、调度任务、发出警告)资源使用

资源使用

指运行此进程所消耗的机器资源。例如内存、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的区别有两方面:

beforeExit里面可以执行异步代码、exit只能是同步代

码手动调用process.exit()或者触发uncaptException导致进程退出不会触发beforeExit事件、exit事件会触发。

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

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:http://www.heiqu.com/887416983712d09b18ccb0287520ca4a.html