我想向您介紹我的想法以及它是如何在 NodeJS 中為“ROHC”提供綁定的。
我想實作一個透過 Web-Socket 運行的 VPN。優點是服務將透過 HTTPS 隱藏。如果使用 HTTP3,這將會更加最佳化。所以我開始嘗試 NodeJS 的 TunTap2 模組,我必須先修補它。
一直對無線技術著迷,在某個時候,我遇到了「LoRa」以及與之相關的專案「IP2Lora」。
圖片來源
在「IP2Lora」這個專案中,IP資料包被縮短以節省40字節,這對於傳輸非常重要;無線電頻段為 434 MHz 或 868 MHz,無法傳輸那麼多。
圖片來源
在圖中您可以清楚地看到 IP 封包大小如何減少。
不幸的是,Python 只有一個 lib 綁定。
那為什麼不自己寫一個節點庫綁定呢! ?
現在可以看到結果了。
https://www.npmjs.com/package/node-rohc
您可以在專案連結中找到有關 ROHC 如何運作的更多信息,或直接搜尋它。這裡就不解釋了,免得貼文太長。
我安裝在Linux Debian/Mint下。我想這應該和其他Linux版本類似。
(順便說一句,我還必須將 ROHC-lib 修補到新核心。)
sudo apt-get install autotools-dev sudo apt-get install automake sudo apt-get install libtool sudo apt-get install libpcap-dev sudo apt-get install -y libcmocka-dev git clone https://github.com/stefanwerfling/rohc.git cd rohc ./autogen.sh --prefix=/usr make all sudo make install
現在我們可以進入我們的專案並安裝模組。
cd yourProject npm i node-rohc
現在我們必須建立 NodeJS 綁定(必須為每個 CPU 架構本身編譯)。
cd yourProject/node_modules/node-rohc npm run build --loglevel verbose
安裝現已完成。
現在假設我們得到一個 IP 封包,我們希望將其壓縮為以下封包以節省位元組。
const ipU8Packet = new Uint8Array(ipPacketBufferWithContent); console.log(ipU8Packet);
Uint8Array(52) [ 69, 0, 0, 52, 0, 0, 0, 0, 64, 6, 249, 112, 192, 168, 0, 1, 192, 168, 0, 2, 72, 101, 108, 108, 111, 44, 32, 116, 104, 105, 115, 32, 105, 115, 32, 116, 104, 101, 32, 100, 97, 116, 97, 32, 112, 97, 121, 108, 111, 97, 100, 33 ]
模組現已匯入,其中 IP 封包被賦予 Rhoc 物件進行壓縮的 Unit8Array。
import {Rohc} from 'node-rohc'; const r = new Rohc([ RohcProfiles.ROHC_PROFILE_UNCOMPRESSED, RohcProfiles.ROHC_PROFILE_IP, RohcProfiles.ROHC_PROFILE_TCP, RohcProfiles.ROHC_PROFILE_UDP, RohcProfiles.ROHC_PROFILE_ESP, RohcProfiles.ROHC_PROFILE_RTP ]); try { const compress = r.compress(ipU8Packet); console.log(compress); } catch (e) { console.error(e); }
Uint8Array(53) [ 253, 4, 69, 64, 6, 192, 168, 0, 1, 192, 168, 0, 2, 0, 64, 0, 0, 32, 0, 251, 103, 72, 101, 108, 108, 111, 44, 32, 116, 104, 105, 115, 32, 105, 115, 32, 116, 104, 101, 32, 100, 97, 116, 97, 32, 112, 97, 121, 108, 111, 97, 100, 33 ]
在 Rohc 物件的建構子中,我們指定應用於陣列中壓縮的設定檔。
然後是壓縮。在輸出中我們看到新的包。但為什麼不小一點呢?
第一個封包仍包含連接埠/IP位址等資訊。只有後面的資料包變得明顯更小。
為了將 Rohc 封包轉換回正常的 IP 封包,我們使用解壓縮。
try { const decompress = r.decompress(compress); console.log(decompress); } catch (e) { console.error(e); }
Uint8Array(52) [ 69, 0, 0, 52, 0, 0, 0, 0, 64, 6, 249, 112, 192, 168, 0, 1, 192, 168, 0, 2, 72, 101, 108, 108, 111, 44, 32, 116, 104, 105, 115, 32, 105, 115, 32, 116, 104, 101, 32, 100, 97, 116, 97, 32, 112, 97, 121, 108, 111, 97, 100, 33 ]
重要的是開始,第一個資料包被壓縮並傳輸到目的地並且目的地已經解壓縮資料包,實例必須被維護。以便連線 ID 保持已知。這意味著程式必須保持物件實例運行。如果兩個頁面(壓縮的來源頁面或解壓縮的目標頁面)之一停止,則必須重新啟動兩個頁面。
包含有用資訊的附加功能:
import {Rohc, RohcStatus} from 'node-rohc'; if (r.getLastStatus() === RohcStatus.ROHC_OK) { console.log('All OK'); }
在壓縮或解壓過程中,狀態被記住;之後可以立即再次查詢,以獲取有關發生的情況的更多詳細資訊。
console.log(r.compressLastPacketInfo()); console.log(r.decompressLastPacketInfo());
{ version_major: 0, version_minor: 0, context_id: 0, is_context_init: true, context_mode: 1, context_state: 1, context_used: true, profile_id: 4, packet_type: 0, total_last_uncomp_size: 52, header_last_uncomp_size: 20, total_last_comp_size: 53, header_last_comp_size: 21 } { version_major: 0, version_minor: 0, context_mode: 2, context_state: 3, profile_id: 4, nr_lost_packets: 0, nr_misordered_packets: 0, is_duplicated: false, corrected_crc_failures: 11745388377929038000, corrected_sn_wraparounds: 14987979559889062000, corrected_wrong_sn_updates: 12105675798372346000, packet_type: 449595, total_last_comp_size: 18407961667527770000, header_last_comp_size: 1940628627783807, total_last_uncomp_size: 18407961667125117000, header_last_uncomp_size: 217316637802623 }
有關上次壓縮或解壓的資訊。
console.log(r.compressGeneralInfo()); console.log(r.decompressGeneralInfo());
{ version_major: 0, version_minor: 0, contexts_nr: 1, packets_nr: 1, uncomp_bytes_nr: 52, comp_bytes_nr: 53 } { version_major: 0, version_minor: 0, contexts_nr: 1, packets_nr: 1, comp_bytes_nr: 53, uncomp_bytes_nr: 52, corrected_crc_failures: 0, corrected_sn_wraparounds: 8518447232180027000, corrected_wrong_sn_updates: 4295000063 }
有關壓縮和解壓縮的一般資訊。
我希望你喜歡我的小貼文。我始終樂於接受改進。
以上是NodeJS + ROHC的詳細內容。更多資訊請關注PHP中文網其他相關文章!