国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Node.js process模塊解讀

Riddler / 2838人閱讀

摘要:默認情況下,會打印堆棧信息到然后退出進程。適用于父子進程之間發送消息,關于如何創建父子進程會放在模塊中進行。信號雖然也是用于請求終止進程,但是它與有所不同,進程可以選擇響應還是忽略此信號。

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

讀:獲取進程信息(資源使用、運行環境、運行狀態)

寫:執行進程操作(監聽事件、調度任務、發出警告)

資源使用

資源使用指運行此進程所消耗的機器資源。例如內存、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架構、用戶環境、系統平臺

運行目錄
console.log(`Current directory: ${process.cwd()}`);

// Current directory: /Users/xxxx/workspace/learn/node-basic/process
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
監聽事件

process是EventEmiiter的實例對象,因此可以使用process.on("eventName", () => {})來監聽事件。
常用的事件類型分兩種:

進程狀態 比如:beforeExit、exit、uncaughtException、message

信號事件 比如:SIGTERM、SIGKILL、SIGUSR1

beforeExit與exit的區別有兩方面:

beforeExit里面可以執行異步代碼、exit只能是同步代碼

手動調用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模塊中進行。

SIGTERM信號雖然也是用于請求終止Node.js進程,但是它與SIGKILL有所不同,進程可以選擇響應還是忽略此信號。
SIGTERM會以一種友好的方式來結束進程,在進程結束之前先釋放已分配的資源(比如數據庫連接),因此這種方式被稱為優雅關閉(graceful shutdown)
具體的執行步驟如下:

應用程序被通知需要關閉(接收到SIGTERM信號)

應用程序通知負載均衡不再接收新的請求

應用程序完成正在進行中的請求

釋放資源(例如數據庫連接)

應用程序正常退出,退出狀態碼為0

SIGUSR1
Node.js當接收到SIGUSR1信號時會啟動內置的調試器,當執行下列操作時

kill -USR1 PID_OF_THE_NODE_JS_PROCESS

可以看到node.js會啟動調試器代理,端口是9229

server is listening 8089
Debugger listening on ws://127.0.0.1:9229/7ef98ccb-02fa-451a-8954-4706bd74105f
For help, see: https://nodejs.org/en/docs/inspector

也可以在服務啟動時使用--inspect 來啟動調試代理

node --inspect index.js
調度任務

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時,可以通過命令行選項施加影響

--throw-deprecation 會拋出異常

--no-deprecation 不輸出DeprecationWarning

--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

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/107838.html

相關文章

  • Node.js child_process模塊解讀

    摘要:而且方式創建的子進程與父進程之間建立了通信管道,因此子進程和父進程之間可以通過的方式發送消息。與事件的回調函數有兩個參數和,代碼子進程最終的退出碼,如果子進程是由于接收到信號終止的話,會記錄子進程接受的值。 在介紹child_process模塊之前,先來看一個下面的代碼。 const http = require(http); const longComputation = () =>...

    baiy 評論0 收藏0
  • 關于Node.js的__dirname,__filename,process.cwd(),./文件路

    摘要:先把當成文件,依次查找當前目錄下的,找到了,就返回該文件,不再繼續執行。那么關于正確的結論是在中使用是跟的效果相同,不會因為啟動腳本的目錄不一樣而改變,在其他情況下跟效果相同,是相對于啟動腳本所在目錄的路徑。 起因 原文收錄在我的 GitHub博客 (https://github.com/jawil/blog) ,喜歡的可以關注最新動態,大家一起多交流學習,共同進步,以學習者的身份寫博...

    harryhappy 評論0 收藏0
  • 關于Node.js的__dirname,__filename,process.cwd(),./文件路

    摘要:先把當成文件,依次查找當前目錄下的,找到了,就返回該文件,不再繼續執行。那么關于正確的結論是在中使用是跟的效果相同,不會因為啟動腳本的目錄不一樣而改變,在其他情況下跟效果相同,是相對于啟動腳本所在目錄的路徑。 起因 原文收錄在我的 GitHub博客 (https://github.com/jawil/blog) ,喜歡的可以關注最新動態,大家一起多交流學習,共同進步,以學習者的身份寫博...

    pumpkin9 評論0 收藏0
  • 如何打造一個令人愉悅的前端開發環境(四)

    摘要:在前后端分離的前端項目開發中經常用到。是的一個中間件。即是一個重要的功能。配置先來在配置文件中引入添加一個和通信的客戶端添加應用入口文件在插件中引入在我們的開發環境中是這樣配置的。 原文鏈接此文是我同事寫的,搭建Express結合Webpack。以下是正文,后面我會附上我的解讀 Express 結合 Webpack 實現HMR 本篇文件主要講結合 Webpack 和 Express 實...

    StonePanda 評論0 收藏0

發表評論

0條評論

Riddler

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<