資料介紹
軟件簡介
binary_log 是一個用于 C++ 的快速二進制記錄器。
Highlights
- 以緊湊的二進制格式記錄消息
-
快速地
- 每秒數(shù)億條日志
- 基本數(shù)據(jù)類型的平均延遲為2-7 ns
- 查看基準
- 提供解包器來壓縮日志消息
- 使用?fmtlib?格式化日志
- 同步日志記錄 - 不是線程安全的
-
Header-only library
- 此處提供單個頭文件版本
- 需要 C++20
Usage and Performance
以下代碼將 10 億個整數(shù)記錄到文件中。
#include <binary_log/binary_log.hpp> int main() { binary_log::binary_log log("log.out"); for (int i = 0; i < 1E9; ++i) BINARY_LOG(log, "Hello logger, msg number: {}", i); }
在一個現(xiàn)代工作站桌面上,上述代碼的執(zhí)行時間為~3.5秒。
Type | Value |
---|---|
Time Taken | 3.5 s |
Throughput | 1.4 Gb/s |
Performance | 286 million logs/s |
Average Latency | 3.5 ns |
File Size | ~5 GB |
foo@bar:~/dev/binary_log$ time ./build/examples/billion_integers/billion_integers real 0m3.561s user 0m2.422s sys 0m1.141s foo@bar:~/dev/binary_log$ ls -lart log.out* -rw-r--r-- 1 pranav pranav 6 Dec 6 07:52 log.out.runlength -rw-r--r-- 1 pranav pranav 32 Dec 6 07:52 log.out.index -rw-r--r-- 1 pranav pranav 4999934337 Dec 6 07:52 log.out
設(shè)計目標(biāo)和決策
-
實現(xiàn)單線程同步記錄器 - 不提供線程安全
- 如果用戶想要多線程行為,用戶可以選擇并實現(xiàn)自己的排隊解決方案
- 有許多眾所周知的無鎖隊列可用于此目的(moody::concurrentqueue、atomic_queue等)——讓用戶選擇他們想要使用的技術(shù)。
-
進入無鎖隊列的延遲足夠大
- 不關(guān)心多線程場景的用戶不應(yīng)該為此付出代價
- 查看atomic_queue benchmarks,在許多最先進的多生產(chǎn)者、多消費者隊列中發(fā)送和接收 4 字節(jié)整數(shù)(在 2 個線程之間,使用 2 個隊列)的平均往返延遲約為150-250 納秒。
- 避免多次寫入靜態(tài)信息
-
在運行時 hot path?中做盡可能少的工作
- 沒有任何形式的格式
- 所有格式化都將使用解壓縮二進制日志的解包器脫機進行
運作方式
binary_log
?將日志拆分為三個文件:
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- STM32GUI使用TouchGFX二進制字體(Binary Font)功能實現(xiàn)字體動態(tài)更新
- 使用TouchGFX二進制翻譯(Binary Translation)功能實現(xiàn)動態(tài)更新翻譯
- 基于Arduino Uno的二進制時鐘 0次下載
- 基于FPGA的二進制相移鍵控設(shè)計方案 12次下載
- PLC實例講解之計數(shù)器值以二進制輸出資源下載 22次下載
- 二進制轉(zhuǎn)十進制的C51程序免費下載
- KEIL C51二進制數(shù)輸入宏的詳細方法程序說明 17次下載
- C6000系列嵌入式應(yīng)用二進制接口 3次下載
- 二進制加計數(shù)器淺析 6次下載
- 3位二進制計數(shù)器 1次下載
- “非二進制”中的新結(jié)構(gòu) 5次下載
- C語言教程之十進制轉(zhuǎn)換為二進制 0次下載
- C#教程之二進制存取圖片 9次下載
- 二進制加法程序【C語言版】 0次下載
- 二進制加法程序【匯編版】 0次下載
- base64字符串轉(zhuǎn)換為二進制文件 1516次閱讀
- 二進制處理中的一些技巧 608次閱讀
- 十進制、十六進制和二進制數(shù)制的區(qū)別 2075次閱讀
- 二進制加法的實現(xiàn)細節(jié) 2855次閱讀
- 二進制編碼器和二-十進制編碼器講解 1.3w次閱讀
- 格雷碼與二進制轉(zhuǎn)換 5355次閱讀
- 數(shù)字二進制計數(shù)器的設(shè)計和實現(xiàn) 1868次閱讀
- 基于FPGA的二進制時鐘設(shè)計方案 2268次閱讀
- 二進制解碼器到底是什么 6270次閱讀
- 如何利用二進制數(shù)實現(xiàn)BCD碼的轉(zhuǎn)換 2.8w次閱讀
- 函數(shù)轉(zhuǎn)換BCD編碼二進制數(shù)為整型數(shù) 6586次閱讀
- 格雷碼與二進制的轉(zhuǎn)換 1.8w次閱讀
- 8421bcd碼轉(zhuǎn)換二進制 7.2w次閱讀
- 二進制數(shù)據(jù)壓縮算法 2w次閱讀
- 解析二進制指數(shù)退避算法的過程 1w次閱讀
下載排行
本周
- 1DD3118電路圖紙資料
- 0.08 MB | 1次下載 | 免費
- 2AD庫封裝庫安裝教程
- 0.49 MB | 1次下載 | 免費
- 3PC6206 300mA低功耗低壓差線性穩(wěn)壓器中文資料
- 1.12 MB | 1次下載 | 免費
- 4網(wǎng)絡(luò)安全從業(yè)者入門指南
- 2.91 MB | 1次下載 | 免費
- 5DS-CS3A P00-CN-V3
- 618.05 KB | 1次下載 | 免費
- 6海川SM5701規(guī)格書
- 1.48 MB | 次下載 | 免費
- 7H20PR5電磁爐IGBT功率管規(guī)格書
- 1.68 MB | 次下載 | 1 積分
- 8IP防護等級說明
- 0.08 MB | 次下載 | 免費
本月
- 1貼片三極管上的印字與真實名稱的對照表詳細說明
- 0.50 MB | 103次下載 | 1 積分
- 2涂鴉各WiFi模塊原理圖加PCB封裝
- 11.75 MB | 89次下載 | 1 積分
- 3錦銳科技CA51F2 SDK開發(fā)包
- 24.06 MB | 43次下載 | 1 積分
- 4錦銳CA51F005 SDK開發(fā)包
- 19.47 MB | 19次下載 | 1 積分
- 5PCB的EMC設(shè)計指南
- 2.47 MB | 16次下載 | 1 積分
- 6HC05藍牙原理圖加PCB
- 15.76 MB | 13次下載 | 1 積分
- 7802.11_Wireless_Networks
- 4.17 MB | 12次下載 | 免費
- 8蘋果iphone 11電路原理圖
- 4.98 MB | 6次下載 | 2 積分
總榜
- 1matlab軟件下載入口
- 未知 | 935127次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233089次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費下載
- 340992 | 191390次下載 | 10 積分
- 5十天學(xué)會AVR單片機與C語言視頻教程 下載
- 158M | 183342次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81588次下載 | 10 積分
- 7Keil工具MDK-Arm免費下載
- 0.02 MB | 73815次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65989次下載 | 10 積分
評論