JavaScript 起初為瀏覽器設計,沒有讀取或操作二進位資料流的機制。 Buffer類別的引入,則讓NodeJS擁有操作文件流或網路二進位流的能力。 【影片教學推薦:node js教學 】
Buffer基本概念
Buffer 物件的記憶體分配不是在V8的堆疊記憶體中,而是Node在C 層級進行記憶體申請,可以理解為在記憶體中單獨開闢了一部分空間,但是使用時分配記憶體則是由Node層面完成的,釋放也是由Node中v8的gc機制自動控制。 Buffer基本操作,這裡不在贅述,官方文件很詳細。
Buffer效能比較
通常,在網路傳輸中,都需要將資料轉換為Buffer。下面做一個性能比較實驗。
1.使用純字串傳回給客戶端
const http = require('http'); let hello = '' for (var i = 0; i < 10240; i++) { hello += "a"; } console.log(`Hello:${hello.length}`) // hello = Buffer.from(hello); http.createServer((req, res) => { res.writeHead(200); res.end(hello); }).listen(8001);
使用ab -c 200 -t 100
http ://127.0.0.1:8001/指令進行效能測試,發起200個並發客戶端
使用字串,QPS可以達到4019.70,傳輸率為40491.45KB每秒。
2.使用Buffer。將字串轉換為Buffer對象,再發給客戶端。
const http = require('http'); let hello = '' for (var i = 0; i < 10240; i++) { hello += "a"; } console.log(`Hello:${hello.length}`) hello = Buffer.from(hello); http.createServer((req, res) => { res.writeHead(200); res.end(hello); }).listen(8001);
取消Buffer轉換的註釋,同樣使用ab -c 200 -t 100
http://127.0.0.1:8001/測試,同樣發起200個並發客戶端
使用Buffer,QPS達到7130.05,傳輸率為71822.74KB每秒。
效能是原來的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提升了很多。
因此,我們在寫業務代碼時,部分資源可以預先轉換為Buffer類型(如js、css等靜態資源文件),直接返回buffer給客戶端,再比如一些文件轉發的場景,將取得的內容儲存為Buffer直接轉發,避免額外的轉換操作。
參考資料:
本文轉載自:https://segmentfault.com/a/1190000016056466
更多程式相關知識,可存取:程式設計教學! !
以上是詳解Node.js Buffer的使用的詳細內容。更多資訊請關注PHP中文網其他相關文章!

我使用您的日常技術工具構建了功能性的多租戶SaaS應用程序(一個Edtech應用程序),您可以做同樣的事情。 首先,什麼是多租戶SaaS應用程序? 多租戶SaaS應用程序可讓您從唱歌中為多個客戶提供服務

本文展示了與許可證確保的後端的前端集成,並使用Next.js構建功能性Edtech SaaS應用程序。 前端獲取用戶權限以控制UI的可見性並確保API要求遵守角色庫

JavaScript是現代Web開發的核心語言,因其多樣性和靈活性而廣泛應用。 1)前端開發:通過DOM操作和現代框架(如React、Vue.js、Angular)構建動態網頁和單頁面應用。 2)服務器端開發:Node.js利用非阻塞I/O模型處理高並發和實時應用。 3)移動和桌面應用開發:通過ReactNative和Electron實現跨平台開發,提高開發效率。

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

Python更适合数据科学和机器学习,JavaScript更适合前端和全栈开发。1.Python以简洁语法和丰富库生态著称,适用于数据分析和Web开发。2.JavaScript是前端开发核心,Node.js支持服务器端编程,适用于全栈开发。

JavaScript不需要安裝,因為它已內置於現代瀏覽器中。你只需文本編輯器和瀏覽器即可開始使用。 1)在瀏覽器環境中,通過標籤嵌入HTML文件中運行。 2)在Node.js環境中,下載並安裝Node.js後,通過命令行運行JavaScript文件。

如何在Quartz中提前發送任務通知在使用Quartz定時器進行任務調度時,任務的執行時間是由cron表達式設定的。現�...


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

Dreamweaver Mac版
視覺化網頁開發工具

禪工作室 13.0.1
強大的PHP整合開發環境