這篇文章帶給大家的內容是關於Nodejs中buffer是什麼? Nodejs中buffer類別的用法,有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。
JavaScript 起初為瀏覽器設計,沒有讀取或操作二進位資料流的機制。 Buffer類別的引入,則讓NodeJS擁有操作檔案流或網路二進位流的能力。
Buffer基本概念
Buffer 物件的記憶體分配不是在V8的堆記憶體中,而是Node在C 層面進行記憶體申請,可以理解為在記憶體中單獨開啟了一部分空間,但是使用時分配記憶體則是由Node層面完成的,釋放也是由Node中v8的gc機制自動控制。 Buffer基本操作,這裡不在贅述,官方文件很詳細。
Buffer效能比較
通常,在網路傳輸中,都需要將資料轉換為Buffer。下面做一個性能比較實驗。
1.使用純字串傳回給客戶端
const http = require('http'); let hello = '' for (var i = 0; i { res.writeHead(200); res.end(hello); }).listen(8001);
使用ab -c 200 -t 100
http:// 127.0.0.1:8001/指令來進行效能測試,發起200個並發客戶端
2.使用Buffer。將字串轉換為Buffer對象,再發給客戶端。
const http = require('http'); let hello = '' for (var i = 0; i { res.writeHead(200); res.end(hello); }).listen(8001);取消Buffer轉換的註釋,同樣使用
ab -c 200 -t 100 http://127.0.0.1:8001/測試,同樣發起200個並發客戶端。
效能是原來的177%,極大的節省了伺服器資源。
上面這個對比範例參考於《深入淺出Node JS》。
那麼問題來了,為什麼會有這麼大的效能提升呢?
道理其實很簡單,在NodeJS中,進行http傳輸時,若傳回的型別為string,則會將
string類型的參數,轉換為Buffer,透過NodeJS中的Stream流,一點點的回傳給客戶端。如果我們直接回傳Buffer類型,就沒有了轉換操作,直接返回,減少了CPU的重複使用率。這一部分邏輯請參考Node原始碼https://github.com/nodejs/node/blob/v10.9.0/lib/_http_outgoing.js#L612
string時,每次請求都需要將
string裝換成Buffer返回;而直接回傳Buffer時,這個Buffer是我們啟動服務時就存放在記憶體中的,每次請求直接回傳記憶體中的Buffer即可,因此Buffer使用前後QPS提升了許多。
以上是Nodejs中buffer是什麼? Nodejs中buffer類別的用法的詳細內容。更多資訊請關注PHP中文網其他相關文章!