<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題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關鍵字專題關鍵字專題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
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        Node.js筆記之process模塊解讀

        來源:懂視網 責編:小采 時間:2020-11-27 22:13:47
        文檔

        Node.js筆記之process模塊解讀

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

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

        1. 讀:獲取進程信息(資源使用、運行環境、運行狀態)
        2. 寫:執行進程操作(監聽事件、調度任務、發出警告)資源使用

        資源使用

        指運行此進程所消耗的機器資源。例如內存、cpu

        內存

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

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

        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見下圖,后面會做進一步詳細的講解

        發出警告

        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

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

        文檔

        Node.js筆記之process模塊解讀

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

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: av无码免费一区二区三区| 久久美女网站免费| 女人18毛片水最多免费观看 | 亚洲成AV人片在WWW色猫咪| 一个人免费播放在线视频看片| 国产最新凸凹视频免费| 精品特级一级毛片免费观看| 国产片免费在线观看| 无码日韩人妻AV一区免费l| 亚洲日韩在线观看免费视频| 亚洲阿v天堂在线2017免费| 在线亚洲97se亚洲综合在线| 99久久国产精品免费一区二区 | 亚洲熟伦熟女新五十路熟妇| 男女一进一出抽搐免费视频 | 国产又粗又长又硬免费视频| 亚洲国产成人AV网站| 亚洲国产人成中文幕一级二级| 国产成人精品免费视频大全| 亚洲欧洲美洲无码精品VA| 色欲色香天天天综合网站免费| 亚洲人成高清在线播放| 免费特级黄毛片在线成人观看| 国产精品亚洲小说专区| 亚洲精品亚洲人成人网| 6080午夜一级毛片免费看| 亚洲三级在线观看| 亚洲日韩在线第一页| 精品无码无人网站免费视频 | 久久亚洲精品国产精品黑人| 在线观看免费高清视频| 黄色网页免费观看| 亚洲国产国产综合一区首页| 成年性羞羞视频免费观看无限| 大片免费观看92在线视频线视频| 久久精品亚洲综合专区| 日本一区二区三区日本免费| 免费看一区二区三区四区 | 一级做a爱过程免费视| 亚洲综合亚洲国产尤物| 免费一级毛片免费播放|