资料介绍
软件简介
binary_log 是一个用于 C++ 的快速二进制记录器。
Highlights
- 以紧凑的二进制格式记录消息
-
快速地
- 每秒数亿条日志
- 基本数据类型的平均延迟为2-7 ns
- 查看基准
- 提供解包器来压缩日志消息
- 使用 fmtlib 格式化日志
- 同步日志记录 - 不是线程安全的
-
Header-only library
- 此处提供单个头文件版本
- 需要 C++20
Usage and Performance
以下代码将 10 亿个整数记录到文件中。
#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); }
在一个现代工作站桌面上,上述代码的执行时间为~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
设计目标和决策
-
实现单线程同步记录器 - 不提供线程安全
- 如果用户想要多线程行为,用户可以选择并实现自己的排队解决方案
- 有许多众所周知的无锁队列可用于此目的(moody::concurrentqueue、atomic_queue等)——让用户选择他们想要使用的技术。
-
进入无锁队列的延迟足够大
- 不关心多线程场景的用户不应该为此付出代价
- 查看atomic_queue benchmarks,在许多最先进的多生产者、多消费者队列中发送和接收 4 字节整数(在 2 个线程之间,使用 2 个队列)的平均往返延迟约为150-250 纳秒。
- 避免多次写入静态信息
-
在运行时 hot path 中做尽可能少的工作
- 没有任何形式的格式
- 所有格式化都将使用解压缩二进制日志的解包器脱机进行
运作方式
binary_log
将日志拆分为三个文件:
下载该资料的人也在下载
下载该资料的人还在阅读
更多 >
- STM32GUI使用TouchGFX二进制字体(Binary Font)功能实现字体动态更新
- 使用TouchGFX二进制翻译(Binary Translation)功能实现动态更新翻译
- 基于Arduino Uno的二进制时钟 0次下载
- 基于FPGA的二进制相移键控设计方案 11次下载
- PLC实例讲解之计数器值以二进制输出资源下载 22次下载
- 二进制转十进制的C51程序免费下载
- KEIL C51二进制数输入宏的详细方法程序说明 17次下载
- C6000系列嵌入式应用二进制接口 3次下载
- 二进制加计数器浅析 6次下载
- 3位二进制计数器 1次下载
- “非二进制”中的新结构 5次下载
- C语言教程之十进制转换为二进制 0次下载
- C#教程之二进制存取图片 9次下载
- 二进制加法程序【C语言版】 0次下载
- 二进制加法程序【汇编版】 0次下载
- 二进制处理中的一些技巧 337次阅读
- 十进制、十六进制和二进制数制的区别 1236次阅读
- 二进制加法的实现细节 2207次阅读
- 二进制编码器和二-十进制编码器讲解 1.1w次阅读
- 格雷码与二进制转换 4547次阅读
- 构建一个4位二进制计数器 4197次阅读
- 数字二进制计数器的设计和实现 1656次阅读
- 基于FPGA的二进制时钟设计方案 2065次阅读
- 二进制解码器到底是什么 6078次阅读
- 如何利用二进制数实现BCD码的转换 2.7w次阅读
- 函数转换BCD编码二进制数为整型数 6404次阅读
- 格雷码与二进制的转换 1.7w次阅读
- 8421bcd码转换二进制 7.1w次阅读
- 二进制数据压缩算法 1.9w次阅读
- 解析二进制指数退避算法的过程 1w次阅读
下载排行
本周
- 1山景DSP芯片AP8248A2数据手册
- 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开发指南
- 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数字电路基础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次下载 | 免费
评论
查看更多