電子發(fā)燒友App

硬聲App

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>電子資料>binary_log用于C++的快速二進制記錄器

binary_log用于C++的快速二進制記錄器

2022-06-16 | zip | 0.45 MB | 次下載 | 2積分

資料介紹

授權(quán)協(xié)議 MIT
開發(fā)語言 C/C++
軟件類型 開源軟件

軟件簡介

binary_log 是一個用于 C++ 的快速二進制記錄器。

Highlights

  • 以緊湊的二進制格式記錄消息
  • 快速地
    • 每秒數(shù)億條日志
    • 基本數(shù)據(jù)類型的平均延遲為2-7 ns
    • 查看基準(zhǔn)
  • 提供解包器來壓縮日志消息
  • 使用?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)信息
    • 靜態(tài)信息示例:格式字符串、格式參數(shù)的數(shù)量以及每個格式參數(shù)的類型
    • 將靜態(tài)信息存儲在“索引”文件中
    • 將動態(tài)信息存儲在日志文件中(盡可能參考索引文件)
  • 在運行時 hot path?中做盡可能少的工作
    • 沒有任何形式的格式
    • 所有格式化都將使用解壓縮二進制日志的解包器脫機進行

運作方式

binary_log?將日志拆分為三個文件:

poYBAGKoB-iAGCmwAAMO3JWjGCw169.png

?

下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1DC電源插座圖紙
  2. 0.67 MB   |  2次下載  |  免費
  3. 2AN119A-使用高度集成的DC/DC uModule穩(wěn)壓器系統(tǒng)為基于FPGA的復(fù)雜系統(tǒng)供電
  4. 499.88KB   |  次下載  |  免費
  5. 3AN52-凌力爾特雜志電路合集,第1卷
  6. 185.9KB   |  次下載  |  免費
  7. 4AN160-具有遠(yuǎn)程溫度檢測功能的單通道電源監(jiān)控器
  8. 451.34KB   |  次下載  |  免費
  9. 5AN-423: 直接數(shù)字頻率合成器AD9850的幅度調(diào)制
  10. 159.13KB   |  次下載  |  免費
  11. 6AN-1451: 用于電能計量應(yīng)用的RS-485故障安全和信號丟失檢測器
  12. 372.18KB   |  次下載  |  免費
  13. 7EE-88:使用21xx編譯器在C中初始化變量
  14. 289.34KB   |  次下載  |  免費
  15. 8AN-644:在微型轉(zhuǎn)換器上使用定時器2進行頻率測量(uC013)
  16. 62.47KB   |  次下載  |  免費

本月

  1. 1ADI高性能電源管理解決方案
  2. 2.43 MB   |  450次下載  |  免費
  3. 2免費開源CC3D飛控資料(電路圖&PCB源文件、BOM、
  4. 5.67 MB   |  138次下載  |  1 積分
  5. 3基于STM32單片機智能手環(huán)心率計步器體溫顯示設(shè)計
  6. 0.10 MB   |  129次下載  |  免費
  7. 4使用單片機實現(xiàn)七人表決器的程序和仿真資料免費下載
  8. 2.96 MB   |  44次下載  |  免費
  9. 53314A函數(shù)發(fā)生器維修手冊
  10. 16.30 MB   |  31次下載  |  免費
  11. 6美的電磁爐維修手冊大全
  12. 1.56 MB   |  22次下載  |  5 積分
  13. 7如何正確測試電源的紋波
  14. 0.36 MB   |  17次下載  |  免費
  15. 8感應(yīng)筆電路圖
  16. 0.06 MB   |  10次下載  |  免費

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935121次下載  |  10 積分
  3. 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計
  4. 1.48MB  |  420062次下載  |  10 積分
  5. 3Altium DXP2002下載入口
  6. 未知  |  233088次下載  |  10 積分
  7. 4電路仿真軟件multisim 10.0免費下載
  8. 340992  |  191367次下載  |  10 積分
  9. 5十天學(xué)會AVR單片機與C語言視頻教程 下載
  10. 158M  |  183335次下載  |  10 積分
  11. 6labview8.5下載
  12. 未知  |  81581次下載  |  10 積分
  13. 7Keil工具MDK-Arm免費下載
  14. 0.02 MB  |  73810次下載  |  10 積分
  15. 8LabVIEW 8.6下載
  16. 未知  |  65988次下載  |  10 積分