用Babeltrace API计数所有事件
count all events in stream with babeltrace API
我有一个 LTTNg
跟踪,我使用babeltrace api来解析。因此,我想知道我是否可以在无需迭代的情况下计算所有事件(或流)中的所有事件。我可以使用Publilc API的哪些功能?
CTF的本质使得无法在恒定时间内计算给定数据包的事件记录。数据包的上下文可以以某种方式包括事件记录计数字段,但未指定,因此通用工具不会使用它。
因此,不幸的是,计算事件的唯一方法是迭代事件记录。最简单的方法是计算babeltrace(1)
工具的text
格式打印的行数:
babeltrace /path/to/ctf/trace/directory | wc --lines
只要每个打印事件记录有一行,除非事件记录包含一个具有新线的字符串字段(目前未在文本输出中逃脱)。
您也可能希望考虑放弃的事件记录。它们不是由babeltrace(1)
打印到标准输出的,但是该工具将打印一条消息,包括检测到标准错误的计数。
当前的babeltrace(1)
工具无法仅打印属于给定数据流的数据包的事件记录。如果需要的话,我建议您删除所有数据流文件,除了需要事件记录计数的文件,然后再次运行上面的命令。
也考虑Babeltrace Python绑定,例如(未测试):
import babeltrace
def count_ctf_event_records(path):
trace_collection = babeltrace.TraceCollection()
trace_collection.add_trace(path, 'ctf')
return sum(1 for event in trace_collection.events)
if __name__ == '__main__':
import sys
print(count_ctf_event_records(sys.argv[1]))
保存为count.py
,您可以尝试以下方法:
python3 count.py /path/to/ctf/trace/directory
将特定数据流的事件记录与python绑定一起作为读者的练习。
这样说,我不知道Python绑定方法是否比babeltrace(1)
One更快。
相关文章:
- Android NDK传感器向事件队列报告奇怪的间隔
- 从文本文件中读取时钟时间和事件时间并进行处理
- WMI检测进程创建事件-c++
- EvtExportLogneneneba API正在将远程计算机的事件日志保存到远程PC本身.如何将其保存到主机
- 处理闪烁窗口事件
- C++Builder中的OnClick事件签名存在问题
- 跟踪滚动条上的鼠标事件
- 什么是事件表 (wxWidgets)?
- 如何在 MFCaptureEngine 中获取"Camera removed"事件
- 给定顺序中的事件处理
- 当服务中的事件被触发时,如何将响应从服务发送回客户端?
- 在 C++/CLI 中将 .NET 事件从一个 DLL 引发到另一个 DLL
- 如何创建事件驱动的 SDL2 应用程序
- Windows 进程间同步类似事件?
- 如何从C++端挂接到 QML 项的 onClick 事件
- 如何通过多类"Union variable" (sfml) 使用轮询事件
- 如何在Qt 4.8中阻止/忽略/丢弃早于特定超时的用户输入事件
- C++ 信号和插槽不工作:插槽不响应事件
- 在虚幻引擎中触发C++ dll的事件
- 用Babeltrace API计数所有事件