• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

    Node.js筆記之process模塊解讀

    來源:懂視網(wǎng) 責(zé)編:小采 時間:2020-11-27 22:13:47
    文檔

    Node.js筆記之process模塊解讀

    Node.js筆記之process模塊解讀:process存在于全局對象上,不需要使用require()加載即可使用,process模塊主要做兩方面的事情 讀:獲取進(jìn)程信息(資源使用、運(yùn)行環(huán)境、運(yùn)行狀態(tài)) 寫:執(zhí)行進(jìn)程操作(監(jiān)聽事件、調(diào)度任務(wù)、發(fā)出警告)資源使用 資源使用 指運(yùn)行此進(jìn)程所消耗的機(jī)器資源。例如
    推薦度:
    導(dǎo)讀Node.js筆記之process模塊解讀:process存在于全局對象上,不需要使用require()加載即可使用,process模塊主要做兩方面的事情 讀:獲取進(jìn)程信息(資源使用、運(yùn)行環(huán)境、運(yùn)行狀態(tài)) 寫:執(zhí)行進(jìn)程操作(監(jiān)聽事件、調(diào)度任務(wù)、發(fā)出警告)資源使用 資源使用 指運(yùn)行此進(jìn)程所消耗的機(jī)器資源。例如

    process存在于全局對象上,不需要使用require()加載即可使用,process模塊主要做兩方面的事情

    1. 讀:獲取進(jìn)程信息(資源使用、運(yùn)行環(huán)境、運(yùn)行狀態(tài))
    2. 寫:執(zhí)行進(jìn)程操作(監(jiān)聽事件、調(diào)度任務(wù)、發(fā)出警告)資源使用

    資源使用

    指運(yùn)行此進(jìn)程所消耗的機(jī)器資源。例如內(nèi)存、cpu

    內(nèi)存

    process.memoryUsage())
    
    { rss: 21848064,
     heapTotal: 7159808,
     heapUsed: 4431688,
     external: 8224 
     }

    rss(常駐內(nèi)存)的組成見下圖

    code segment對應(yīng)當(dāng)前運(yùn)行的代碼

    external對應(yīng)的是C++對象(與V8管理的JS對象綁定)的占用的內(nèi)存,比如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對應(yīng)用戶時間,system代表系統(tǒng)時間

    運(yùn)行環(huán)境

    運(yùn)行環(huán)境指此進(jìn)程運(yùn)行的宿主環(huán)境包括運(yùn)行目錄、node環(huán)境、CPU架構(gòu)、用戶環(huán)境、系統(tǒng)平臺

    運(yùn)行目錄

    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環(huán)境

    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架構(gòu)

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

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

    用戶環(huán)境

    console.log(process.env.NODE_ENV); // dev
    
    NODE_ENV=dev node b.js

    除了啟動時的自定義信息之外,process.env還可以獲得其他的用戶環(huán)境信息(比如PATH、SHELL、HOME等),感興趣的可以自己打印一下試試

    系統(tǒng)平臺

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

    支持的系統(tǒng)平臺包括:'aix' 'darwin' 'freebsd' 'linux' 'openbsd' 'sunos' 'win32'

    android目前還處于試驗(yàn)階段

    運(yùn)行狀態(tài)

    運(yùn)行狀態(tài)指當(dāng)前進(jìn)程的運(yùn)行相關(guān)的信息包括啟動參數(shù)、執(zhí)行目錄、主文件、PID信息、運(yùn)行時間

    啟動參數(shù)

    獲取啟動參數(shù)有三個方法,execArgv獲取Node.js的命令行選項(見官網(wǎng)文檔)

    argv獲取非命令行選項的信息,argv0則獲取argv[0]的值(略有差異)

    console.log(process.argv)
    console.log(process.argv0)
    console.log(process.execArgv)
    
    node --harmony b.js foo=bar --version
    
    // 
    輸出結(jié)果 [ '/Users/xiji/.nvm/versions/node/v9.1.0/bin/node', '/Users/xiji/workspace/learn/node-basic/process/b.js', 'foo=bar', '--version' ] node [ '--harmony' ]

    執(zhí)行目錄

    console.log(process.execPath);
    
    // /Users/xxxx/.nvm/versions/node/v9.1.0/bin/node

    運(yùn)行時間

    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

    監(jiān)聽事件

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

    beforeExit與exit的區(qū)別有兩方面:

    1. beforeExit里面可以執(zhí)行異步代碼、exit只能是同步代
    2. 碼手動調(diào)用process.exit()或者觸發(fā)uncaptException導(dǎo)致進(jìn)程退出不會觸發(fā)beforeExit事件、exit事件會觸發(fā)。

    因此下面的代碼console都不會被執(zhí)行

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

    當(dāng)異常一直沒有被捕獲處理的話,最后就會觸發(fā)'uncaughtException'事件。默認(rèn)情況下,Node.js會打印堆棧信息到stderr然后退出進(jìn)程。不要試圖阻止uncaughtException退出進(jìn)程,因此此時程序的狀態(tài)可能已經(jīng)不穩(wěn)定了,建議的方式是及時捕獲處理代碼中的錯誤,uncaughtException里面只做一些清理工作(可以執(zhí)行異步代碼)。

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

    當(dāng)process.setUncaughtExceptionCaptureCallback(fn)指定了監(jiān)聽函數(shù)的時候,uncaughtException事件將會不再被觸發(fā)。

    process.on('uncaughtException', function() {
     console.log('uncaught listener');
    });
    
    process.setUncaughtExceptionCaptureCallback(function() {
     console.log('uncaught fn');
    });
    
    a.b();
    // uncaught fn

    message適用于父子進(jìn)程之間發(fā)送消息,關(guān)于如何創(chuàng)建父子進(jìn)程會放在child_process模塊中進(jìn)行。

    調(diào)度任務(wù)

    process.nextTick(fn)

    通過process.nextTick調(diào)度的任務(wù)是異步任務(wù),EventLoop是分階段的,每個階段執(zhí)行特定的任務(wù),而nextTick的任務(wù)在階段切換的時候就會執(zhí)行,因此nextTick會比setTimeout(fn, 0)更快的執(zhí)行,關(guān)于EventLoop見下圖,后面會做進(jìn)一步詳細(xì)的講解

    發(fā)出警告

    process.emitWarning('Something warning happened!', {
     code: 'MY_WARNING',
     type: 'XXXX'
    });
    
    // (node:14771) [MY_WARNING] XXXX: Something warning happened!

    當(dāng)type為DeprecationWarning時,可以通過命令行選項施加影響

    1. --throw-deprecation 會拋出異常
    2. --no-deprecation 不輸出DeprecationWarning
    3. --trace-deprecation 打印詳細(xì)堆棧信息
    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

    聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    Node.js筆記之process模塊解讀

    Node.js筆記之process模塊解讀:process存在于全局對象上,不需要使用require()加載即可使用,process模塊主要做兩方面的事情 讀:獲取進(jìn)程信息(資源使用、運(yùn)行環(huán)境、運(yùn)行狀態(tài)) 寫:執(zhí)行進(jìn)程操作(監(jiān)聽事件、調(diào)度任務(wù)、發(fā)出警告)資源使用 資源使用 指運(yùn)行此進(jìn)程所消耗的機(jī)器資源。例如
    推薦度:
    標(biāo)簽: 筆記 模塊 解讀
    • 熱門焦點(diǎn)

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 欧美成人精品网站播放| 亚洲日韩精品欧美一区二区| 国产精品99精品久久免费| 国内精品久久久久国产盗摄 | 国产精品一区二区久久精品无码| 精品久久久久久国产91| 中文精品久久久久人妻不卡| 国产精品第1页| 麻豆国产精品VA在线观看不卡| 精品久久久久久亚洲| 日韩精品人妻系列无码专区| 人妻无码精品久久亚瑟影视| 最新国产の精品合集| 国产亚洲精品a在线观看app| 久久国产精品99精品国产| 区亚洲欧美一级久久精品亚洲精品成人网久久久久| 91精品国产麻豆国产自产在线| 成人国产精品一区二区网站| 久久精品国产亚洲av日韩| 亚洲av日韩精品久久久久久a| 下载天堂国产AV成人无码精品网站| 国产精品亚洲美女久久久 | 亚洲乱码日产精品a级毛片久久| 国产精品九九久久免费视频 | 国产在视频线精品视频二代| 国产午夜无码精品免费看动漫| 日韩av无码久久精品免费| 亚洲欧洲美洲无码精品VA| 99在线精品视频在线观看| 久久伊人精品青青草原高清| 国产成人精品日本亚洲网站| 久久夜色精品国产网站| 亚洲AV永久无码精品成人| 亚洲精品第一国产综合境外资源| 国产精品看高国产精品不卡| 久久精品国产亚洲av麻豆小说| 亚洲国产精品成人久久| 亚洲永久精品ww47| 无码人妻精品中文字幕免费| 四虎国产精品永久免费网址| 欧美精品hdvideosex4k|