資料介紹
軟件簡介
binary_log 是一個用于 C++ 的快速二進制記錄器。
Highlights
- 以緊湊的二進制格式記錄消息
-
快速地
- 每秒數(shù)億條日志
- 基本數(shù)據類型的平均延遲為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
設計目標和決策
-
實現(xiàn)單線程同步記錄器 - 不提供線程安全
- 如果用戶想要多線程行為,用戶可以選擇并實現(xiàn)自己的排隊解決方案
- 有許多眾所周知的無鎖隊列可用于此目的(moody::concurrentqueue、atomic_queue等)——讓用戶選擇他們想要使用的技術。
-
進入無鎖隊列的延遲足夠大
- 不關心多線程場景的用戶不應該為此付出代價
- 查看atomic_queue benchmarks,在許多最先進的多生產者、多消費者隊列中發(fā)送和接收 4 字節(jié)整數(shù)(在 2 個線程之間,使用 2 個隊列)的平均往返延遲約為150-250 納秒。
-
避免多次寫入靜態(tài)信息
- 靜態(tài)信息示例:格式字符串、格式參數(shù)的數(shù)量以及每個格式參數(shù)的類型
- 將靜態(tài)信息存儲在“索引”文件中
- 將動態(tài)信息存儲在日志文件中(盡可能參考索引文件)
-
在運行時 hot path?中做盡可能少的工作
- 沒有任何形式的格式
- 所有格式化都將使用解壓縮二進制日志的解包器脫機進行
運作方式
binary_log?將日志拆分為三個文件:

下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- STM32GUI使用TouchGFX二進制字體(Binary Font)功能實現(xiàn)字體動態(tài)更新
- 使用TouchGFX二進制翻譯(Binary Translation)功能實現(xiàn)動態(tài)更新翻譯
- 基于Arduino Uno的二進制時鐘 1次下載
- 基于FPGA的二進制相移鍵控設計方案 12次下載
- 二進制轉十進制的C51程序免費下載
- KEIL C51二進制數(shù)輸入宏的詳細方法程序說明 17次下載
- C6000系列嵌入式應用二進制接口 3次下載
- 二進制加計數(shù)器淺析 6次下載
- 3位二進制計數(shù)器 1次下載
- “非二進制”中的新結構 5次下載
- C語言教程之十進制轉換為二進制 0次下載
- C#教程之二進制存取圖片 9次下載
- 二進制加法程序【C語言版】 0次下載
- 二進制加法程序【匯編版】 0次下載
- TTL二進制同步可逆計數(shù)器
- base64字符串轉換為二進制文件 3.8k次閱讀
- 二進制處理中的一些技巧 1.5k次閱讀
- 十進制、十六進制和二進制數(shù)制的區(qū)別 4.1k次閱讀
- 二進制加法的實現(xiàn)細節(jié) 4.8k次閱讀
- 二進制編碼器和二-十進制編碼器講解 1.6w次閱讀
- 格雷碼與二進制轉換 6.8k次閱讀
- 數(shù)字二進制計數(shù)器的設計和實現(xiàn) 2.4k次閱讀
- 基于FPGA的二進制時鐘設計方案 3.1k次閱讀
- 二進制解碼器到底是什么 7k次閱讀
- 如何利用二進制數(shù)實現(xiàn)BCD碼的轉換 2.9w次閱讀
- 函數(shù)轉換BCD編碼二進制數(shù)為整型數(shù) 7.4k次閱讀
- 格雷碼與二進制的轉換 2w次閱讀
- 8421bcd碼轉換二進制 7.5w次閱讀
- 二進制數(shù)據壓縮算法 2.1w次閱讀
- 解析二進制指數(shù)退避算法的過程 1.1w次閱讀
下載排行
本周
- 1山景DSP芯片AP8248A2數(shù)據手冊
- 1.06 MB | 532次下載 | 免費
- 2RK3399完整板原理圖(支持平板,盒子VR)
- 3.28 MB | 339次下載 | 免費
- 3TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費
- 4DFM軟件使用教程
- 0.84 MB | 295次下載 | 免費
- 5元宇宙深度解析—未來的未來-風口還是泡沫
- 6.40 MB | 227次下載 | 免費
- 6迪文DGUS開發(fā)指南
- 31.67 MB | 194次下載 | 免費
- 7元宇宙底層硬件系列報告
- 13.42 MB | 182次下載 | 免費
- 8FP5207XR-G1中文應用手冊
- 1.09 MB | 178次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 2555集成電路應用800例(新編版)
- 0.00 MB | 33566次下載 | 免費
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費
- 4開關電源設計實例指南
- 未知 | 21549次下載 | 免費
- 5電氣工程師手冊免費下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費
- 6數(shù)字電路基礎pdf(下載)
- 未知 | 13750次下載 | 免費
- 7電子制作實例集錦 下載
- 未知 | 8113次下載 | 免費
- 8《LED驅動電路設計》 溫德爾著
- 0.00 MB | 6656次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費
- 2protel99se軟件下載(可英文版轉中文版)
- 78.1 MB | 537798次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420027次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191187次下載 | 免費
- 7十天學會AVR單片機與C語言視頻教程 下載
- 158M | 183279次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138040次下載 | 免費
電子發(fā)燒友App





創(chuàng)作
發(fā)文章
發(fā)帖
提問
發(fā)資料
發(fā)視頻
上傳資料賺積分
評論