亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

Node.js筆記之process模塊解讀

2024-05-06 16:44:43
字體:
來源:轉載
供稿:網友

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); // devNODE_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.jsconsole.log(`module A: ${process.mainModule === module}`);//b.jsrequire('./a');console.log(`module B: ${process.mainModule === module}`);node b.js// 輸出module A: falsemodule 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.jsnode --no-deprecation index.jsnode --trace-deprecation index.js

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
97婷婷涩涩精品一区| 亚洲免费一级电影| 亚洲精品免费av| 热re99久久精品国产66热| 日韩免费视频在线观看| 欧美日韩日本国产| 色综合久久中文字幕综合网小说| 欧美猛交免费看| 国产男女猛烈无遮挡91| 久久欧美在线电影| 国产精品黄页免费高清在线观看| 亚洲免费小视频| 91最新国产视频| 国产精品老女人视频| 欧美性猛交xxxx乱大交极品| 91精品视频在线免费观看| 久久精品福利视频| 黑人与娇小精品av专区| 国产在线精品一区免费香蕉| 亚洲欧洲一区二区三区在线观看| 成人欧美一区二区三区黑人| 亚洲图片在线综合| 日本一区二区三区四区视频| 欧美精品中文字幕一区| 成人福利视频在线观看| 国语对白做受69| 亚洲精品午夜精品| 北条麻妃99精品青青久久| 国产精品一区二区三| 欧美中文在线免费| 国产在线视频一区| 国产精品一区二区三区毛片淫片| 亚洲高清在线观看| 国产一区二区三区在线看| 欧美疯狂xxxx大交乱88av| 亚洲精品小视频在线观看| 欧美视频在线视频| 亚洲wwwav| 91精品久久久久久综合乱菊| 久久亚洲欧美日韩精品专区| 久久亚洲一区二区三区四区五区高| 欧美激情欧美狂野欧美精品| 亚洲精品网址在线观看| 日韩精品中文字幕有码专区| 亚洲成色999久久网站| 在线视频日韩精品| 国产一区二中文字幕在线看| 日韩精品免费电影| 中文字幕av一区| 深夜成人在线观看| 2018日韩中文字幕| 九九精品视频在线观看| 热久久视久久精品18亚洲精品| 欧美日韩免费在线| 欧美第一黄色网| 久久偷看各类女兵18女厕嘘嘘| 国产丝袜一区二区| 欧美激情18p| 亚洲欧洲偷拍精品| 亚洲高清av在线| 亚洲精品一区久久久久久| 欧美日韩视频免费播放| 全色精品综合影院| 成人亚洲欧美一区二区三区| 亚洲视频在线观看免费| 成人国产精品色哟哟| 精品亚洲va在线va天堂资源站| 国产精品久久久久av| 欧美激情欧美激情在线五月| 亚洲天堂久久av| 亚洲一区中文字幕在线观看| 亚洲区bt下载| 国产成人精品免费视频| 欧美成年人视频网站| 国产精品美女视频网站| 青青草精品毛片| 在线日韩第一页| 欧美日韩性视频在线| 色哟哟亚洲精品一区二区| 亚洲影视九九影院在线观看| 国内精品小视频在线观看| 国产www精品| 最新的欧美黄色| 国产精品欧美亚洲777777| 国产精品日日摸夜夜添夜夜av| 成人激情视频在线观看| 色青青草原桃花久久综合| 久久99国产精品自在自在app| 亚洲三级免费看| 国产成+人+综合+亚洲欧美丁香花| 久久久精品中文字幕| 亚洲精品美女免费| 欧洲美女7788成人免费视频| 在线观看国产精品淫| 亚洲系列中文字幕| 久久久国产精品x99av| 欧美中文字幕精品| 国产精品久久久久久久久借妻| 久久精品2019中文字幕| 亚洲女人被黑人巨大进入| 456国产精品| www.xxxx欧美| 久久深夜福利免费观看| 91国内免费在线视频| 97精品国产91久久久久久| 国产亚洲免费的视频看| 91精品国产综合久久久久久蜜臀| 国产中文欧美精品| 91色精品视频在线| 色老头一区二区三区在线观看| 亚洲人成在线观看| 午夜精品国产精品大乳美女| 夜夜嗨av色一区二区不卡| 精品久久久久久久久久久久久久| 日韩免费在线电影| 91人成网站www| 亚洲美腿欧美激情另类| 538国产精品一区二区免费视频| 911国产网站尤物在线观看| 亚洲精品资源在线| 激情av一区二区| 黄色成人av在线| 国产精品h在线观看| 久久亚洲一区二区三区四区五区高| 亚洲free性xxxx护士白浆| 国产精品久久久久久久久免费| 成人免费在线视频网址| 日韩大陆欧美高清视频区| 九九久久久久久久久激情| 亚洲美女免费精品视频在线观看| 中文字幕亚洲无线码a| 成年无码av片在线| 欧美在线中文字幕| 欧美有码在线观看| 亚洲国产成人在线视频| x99av成人免费| 亚洲成人网在线| 欧美激情精品久久久久久| 97精品国产97久久久久久| 亚洲午夜未满十八勿入免费观看全集| 欧美激情videos| 久久精品一本久久99精品| 在线观看欧美视频| 久热精品视频在线| 久久视频在线视频| 欧美裸体xxxx极品少妇| 78m国产成人精品视频| 欧美成人激情视频免费观看| 国产亚洲精品成人av久久ww| 亚洲福利在线看| 久久精品这里热有精品| 国产日韩精品在线| 亚洲欧洲在线看| 91精品视频免费看| 日韩中文字幕av| 欧美精品免费在线观看| 国产精品女主播| 成人欧美一区二区三区黑人| 91久久久在线| 国产精品亚洲欧美导航| 亚洲国产中文字幕在线观看| 中文字幕亚洲综合久久筱田步美| 国产这里只有精品| 亚洲免费电影一区|