C++编程:高性能通信组件Capnproto与Protobuf的对比分析
文章目录
- 0. 概要
- 1. 测试环境
- 2. 测试方法
- 3. 测试结果及分析
- 3.1 延迟测试
- 3.2 吞吐量测试
- 3.3 稳定性测试
- 3.4 一对二测试记录
- 3.5 二对一测试记录
- 3.6 Inter-process 单个点开销分析
- 4. CapnProto 与 Protobuf 的对比测试总结
0. 概要
本文主要探讨了两种高性能通信组件:CapnProto 和Protobuf。在不同硬件平台下(x86_64与aarch64)进行了延迟、吞吐量、稳定性等方面的测试与分析,并给出了具体的测试代码实现。
1. 测试环境
| 环境 | 内存 | 处理器 | 系统 |
|---|---|---|---|
| x86_64 | 32GB | i7-11800H | Ubuntu 20.04.6 LTS |
| aarch64 | 32GB | ARMv8 | Ubuntu 20.04.4 LTS |
2. 测试方法
测试分为延迟、吞吐量与稳定性三部分,通过C++实现的通信模块进行数据传输测试,记录并分析结果。
2.1 延迟测试
- 测试方式:通过IPC方式在不同协议下不断发送消息,记录发送和接收的时间戳,计算传输延迟。
- 测试工具:
CommMetric.py读取生成的日志文件,统计分析并生成图表。
# CommMetric.py
import csv
import matplotlib.pyplot as pltdef parse_latency_log(file_path):latencies = []with open(file_path, 'r') as file:reader = csv.reader(file)for row in reader:if row:latencies.append(float(row[1])) # 假设延迟在第二列return latenciesdef plot_latency(latencies):plt.figure(figsize=(10, 6))plt.plot(latencies, label='Latency')plt.xlabel('Message Index')plt.ylabel('Latency (ms)')plt.title('Message Latency Over Time')plt.legend()plt.grid(True)plt.show()if __name__ == "__main__":file_path = 'latency_log.csv' # 这里替换为实际的日志文件路径latencies = parse_latency_log(file_path)plot_latency(latencies)
#include <iostream>
#include <chrono>
#include <capnp/serialize.h>
#include <kj/io.h>// 模拟Talker端发送消息
void sendMessages() {for (int i = 0; i < 100; ++i) {auto start = std::chrono::high_resolution_clock::now();// 发送消息操作auto end = std::chrono::high_resolution_clock::now();std::chrono::duration<double, std::milli> elapsed = end - start;std::cout << "Message " << i << " latency: " << elapsed.count() << " ms\n";}
}int main() {sendMessages();return 0;
}
2.2 吞吐量测试
- 测试方式:发送大批量消息,记录传输时间,计算每秒传输的数据量。
- 测试工具:
CommMetric_throughput.py进行统计分析。
# CommMetric_throughput.py
import csvdef parse_throughput_log(file_path):start_time = Noneend_time = Nonedata_size = 0with open(file_path, 'r') as file:reader = csv.reader(file)for row in reader:if row:if start_time is None:start_time = float(row[0]) # 假设开始时间在第一列end_time = float(row[0]) # 假设结束时间也在第一列data_size = float(row[1]) # 假设数据大小在第二列duration = end_time - start_timethroughput = data_size / duration # 吞吐量 = 数据大小 / 持续时间return throughputif __name__ == "__main__":file_path = 'throughput_log.csv' # 这里替换为实际的日志文件路径throughput = parse_throughput_log(file_path)print(f'Throughput: {throughput} bytes/second')
#include <iostream>
#include <chrono>// 模拟Talker端发送消息
void sendBulkMessages() {auto start = std::chrono::high_resolution_clock::now();// 批量发送消息操作auto end = std::chrono::high_resolution_clock::now();std::chrono::duration<double> elapsed = end - start;std::cout << "Total throughput time: " << elapsed.count() << " seconds\n";
}int main() {sendBulkMessages();return 0;
}
2.3 稳定性测试
- 测试方式:长时间运行通信模块,记录长时间运行下的延迟变化。
- 测试工具:记录长时间运行日志,分析延迟波动情况。
#include <iostream>
#include <chrono>// 模拟长时间发送消息
void longTermTest() {for (int i = 0; i < 20000; ++i) {auto start = std::chrono::high_resolution_clock::now();// 发送消息操作auto end = std::chrono::high_resolution_clock::now();std::chrono::duration<double, std::milli> elapsed = end - start;std::cout << "Message " << i << " latency: " << elapsed.count() << " ms\n";}
}int main() {longTermTest();return 0;
}
3. 测试结果及分析
本章节汇总了在不同测试条件下对CapnProto和Protobuf两种序列化协议的性能评估结果,并对它们在延迟、吞吐量、稳定性等方面的表现进行了详细分析。
3.1 延迟测试
延迟测试旨在评估CapnProto和Protobuf在不同硬件平台和负载条件下的延迟表现。测试表明,CapnProto在消息传输的延迟方面优于Protobuf,尤其是在大数据量传输时表现更为显著。
-
x86_64平台:
- 当Payload大小为6.5MB时,CapnProto的延迟为63.133 ms,而Protobuf的延迟为131.145 ms,CapnProto的延迟比Protobuf降低了约52%。
-
aarch64平台:
- 在相同的Payload大小下,CapnProto的延迟为66.840 ms,而Protobuf的延迟高达2092.023 ms,CapnProto在此平台上的延迟表现显著优于Protobuf。
分析:无论是在x86_64还是aarch64平台,CapnProto都展示出了较低的延迟,特别是在大Payload场景下,其性能优势更加明显。这表明CapnProto在处理大数据量时具有更好的效率和响应能力,特别适用于对低延迟有严格要求的应用场景。
3.2 吞吐量测试
吞吐量测试用以衡量CapnProto和Protobuf在高负载情况下的数据传输能力。测试结果显示,CapnProto在大数据传输中的吞吐量明显优于Protobuf,尤其是在高数据负载条件下。
- x86_64平台:
- 在传输1000MB Payload时,CapnProto的吞吐量显著高于Protobuf,表现出更高的数据传输效率。
分析:CapnProto在高负载传输场景下的吞吐量远高于Protobuf,这使得其更适用于大规模数据传输的应用场景。尤其在需要快速处理大量数据的情况下,CapnProto能够提供更好的性能保障。
3.3 稳定性测试
稳定性测试评估了两种序列化协议在长时间运行下的延迟波动和一致性表现。测试结果表明,CapnProto在长时间运行过程中表现出更高的稳定性,而Protobuf的延迟波动较大。
- 长时间运行测试:
- CapnProto在长时间运行下,延迟保持稳定,没有出现显著波动。
- 相比之下,Protobuf的延迟在长时间运行后出现较大波动,可能影响系统的实时性和稳定性。
分析:CapnProto在长时间运行中的稳定性优势使其更加适合需要持续运行且对延迟稳定性要求较高的系统。Protobuf在长时间负载下的波动可能导致系统性能的不可预测性,这在一些关键应用中可能是一个风险。
3.4 一对二测试记录
在一对二的测试场景中,CapnProto在高负载下表现出优异的性能和稳定性,而Protobuf在高负载下的丢帧率明显较高。
CapnProto
| **Payload ** | Times | 丢帧数(Total) | 总时长(Total) |
|---|---|---|---|
| 6.5MB | 100 | 2 | 15,174 ms / 15,177.6 ms |
| 26MB | 100 | 0 | 33,837.6 ms / 33,823.4 ms |
Protobuf
| Payload | Times | 丢帧数(Total) | 总时长(Total) |
|---|---|---|---|
| 6.5MB | 100 | 2 | 17,653.1 ms / 17,652.2 ms |
| 26MB | 100 | 28 | 41,962.9 ms / 41,945.8 ms |
分析:在6.5MB 的负载下,CapnProto和Protobuf的丢帧数相同,但CapnProto的总时长较短。随着负载增加至26MB,Protobuf的丢帧数大幅增加,而CapnProto则继续保持稳定,证明其在高负载下的优越性。
3.5 二对一测试记录
在二对一测试场景中,CapnProto在高负载下同样保持了出色的表现,而Protobuf则在负载增加时表现出明显的性能下降。
CapnProto
| **Payload ** | Times | 丢帧数(Total) | 总时长(Total) |
|---|---|---|---|
| 6.5MB | 100 | 2 | 15,340.9 ms |
| 26MB | 100 | 0 | 35,064.2 ms |
Protobuf
| Payload | Times | 丢帧数(Total) | 总时长(Total) |
|---|---|---|---|
| 6.5MB | 100 | 0 | 19,365.9 ms |
| 26MB | 100 | 25 | 46,472.4 ms |
分析:在6.5MB负载下,Protobuf虽然没有出现丢帧,但总时长仍明显高于CapnProto。在26MB 负载下,Protobuf的丢帧数增至25,而CapnProto保持零丢帧,再次表明了其更高的可靠性和效率。
3.6 Inter-process 单个点开销分析
对于单个点的开销测试,CapnProto和Protobuf在处理时间和稳定性上表现出了明显的差异。
CapnProto
- 单点100次测试:CapnProto在单点100次的测试中表现出稳定且较低的处理时间。
- 单点1次测试:在单次处理的测试中,CapnProto继续表现出较快的响应能力。
Protobuf
- 单点100次测试:Protobuf在100次处理单点的测试中,处理时间较高且波动较大。
- 单点1次测试:在单次处理时,Protobuf的响应速度显著慢于CapnProto。
分析:从单点开销的测试结果来看,CapnProto的处理速度和稳定性明显优于Protobuf,这进一步佐证了其在高频率、低延迟应用场景中的适用性。
4. CapnProto 与 Protobuf 的对比测试总结
在本次测试中,通过对CapnProto和Protobuf在不同硬件平台、不同消息负载下的表现进行对比,我们可以得出:
-
延迟性能:
- x86_64 平台:当Payload大小为6.5MB时,CapnProto的延迟为63.133 ms,而Protobuf的延迟为131.145 ms,CapnProto的延迟提升约52%。
- aarch64 平台:同样的Payload大小下,CapnProto的延迟为66.840 ms,Protobuf的延迟为2092.023 ms,CapnProto在这一平台上表现出显著优势。
-
吞吐量:
- x86_64 平台:在传输1000MB的Payload时,CapnProto的吞吐量明显高于Protobuf,特别是在大消息传输时更为显著。
-
稳定性:
- 在长时间运行测试中,CapnProto表现出更好的稳定性,而Protobuf在长时间运行下延迟波动较大,且出现了更多的丢帧现象。
相关文章:
C++编程:高性能通信组件Capnproto与Protobuf的对比分析
文章目录 0. 概要1. 测试环境2. 测试方法3. 测试结果及分析3.1 延迟测试3.2 吞吐量测试3.3 稳定性测试3.4 一对二测试记录3.5 二对一测试记录3.6 Inter-process 单个点开销分析 4. CapnProto 与 Protobuf 的对比测试总结 0. 概要 本文主要探讨了两种高性能通信组件:…...
【Python读书数据,并计算数据的相关系数、方差,均方根误差】
为了处理Python中的读书数据(假设这里指的是一系列关于书籍阅读量或评分的数据),并计算这些数据的相关系数、方差以及均方根误差(RMSE),我们首先需要明确数据的结构。这里,我将假设我们有一组关…...
垃圾收集器G1ZGC详解
G1收集器(-XX:UseG1GC) G1 (Garbage-First)是一款面向服务器的垃圾收集器,主要针对配备多颗处理器及大容量内存的机器. 以极高概率满足GC停顿时间要求的同时,还具备高吞吐量性能特征. G1将Java堆划分为多个大小相等的独立区域(Region),JVM目…...
AI芯片:高性能卷积计算中的数据复用
随着深度学习的飞速发展,对处理器的性能要求也变得越来越高,随之涌现出了很多针对神经网络加速设计的AI芯片。卷积计算是神经网络中最重要的一类计算,本文分析了高性能卷积计算中的数据复用,这是AI芯片设计中需要优化的重点之一&a…...
gitlab修改默认访问端口
GitLab 自带了一个 Nginx 服务器实例,用于处理 HTTP 和 HTTPS 请求。这个内置的 Nginx 服务器被配置为与 GitLab 应用程序实例一起工作,并且它负责处理所有前端的网络通信。 通过yum或者apt安装Gitlab时,nginx通常是被自带安装并配置好的。 …...
python——异常
Python 中的异常及继承关系 在 Python 中,异常用于表示程序在运行过程中遇到的错误,所有异常类最终都继承自 BaseException。通过异常处理,我们可以捕获和处理这些错误,避免程序崩溃。 Python 异常继承关系图 BaseException-- …...
【人工智能】利用TensorFlow.js在浏览器中实现一个基本的情感分析系统
使用TensorFlow.js在浏览器中进行情感分析是一个非常实用的应用场景。TensorFlow.js 是一个用于在JavaScript环境中训练和部署机器学习模型的库,使得开发者能够在客户端直接运行复杂的机器学习任务。对于情感分析,我们可以使用预先训练好的模型来识别文本…...
Python——扩展数据类型
Python 的扩展数据类型是对内置数据类型的增强,旨在解决特定需求,提供更高级的功能。我们来看一些常见的扩展数据类型及其原理、用途,并通过示例逐步讲解。 1. collections.namedtuple namedtuple 是增强的元组,允许用名称访问元…...
JavaScript 详解——Vue基础
第一章 JavaScript简介 为什么学习javascript ? JavaScript 是全球最流行的编程语言。 JavaScript 是属于 Web 的编程语言。 JavaScript 是 web 开发者必学的三种语言之一: HTML 定义网页的内容 CSS 规定网页的布局 JavaScript 对网页行为进行编程 …...
机械行业数字化生产供应链产品解决方案(十二)
我们为机械行业提供的数字化生产供应链解决方案通过集成物联网、人工智能和大数据技术,打造了一套智能化的生产和供应链管理系统,实现了从设计、生产到物流的全程数字化、智能化。该系统通过实时数据采集与分析,优化生产计划和资源配置&#…...
Git——命令集合
Git命令集合 1. 基本操作 1.1 创建版本库 初始化本地仓库:git init添加文件到仓库:git add | git add file file2… | git add.提交文件到本地仓库:git commit -m “message” 1.2 版本回退 查看状态: git status查看全部修改…...
python 数据可视化折线图练习(下:代码演示)
根据上篇对三国疫情情况数据的罗列,构建折线图完成数据展示。(示例如下) 接下来是具体代码演示 import json from pyecharts.charts import Line from pyecharts.options import TitleOpts , LegendOpts , ToolboxOpts ,VisualMapOpts , T…...
深入探索 Go 1.18 的 debug/buildinfo:构建信息的获取与应用
标题:深入探索 Go 1.18 的 debug/buildinfo:构建信息的获取与应用 引言 Go 语言自 1.18 版本起,引入了对构建信息的标准化处理,这一特性极大地简化了获取程序构建信息的过程。debug/buildinfo 包提供了访问 Go 二进制文件中嵌入…...
Nios II的BSP Editor
1.菜单打开BSP Editor (1) (2) (3) 项目文件夹 -> software文件夹 -> ... _bsp文件夹 -> settings.bsp文件 2.文件打开BSP Editor 选中项目文件,右键,Nios II -> …...
Android-自适用高度的ViewPager
需求 在项目中,我们常常遇到需要动态调整 ViewPager 的高度,以适应其内容大小的需求。默认情况下,ViewPager 的高度是固定的,无法根据每个页面的内容高度进行调整。这会导致在内容高度不一致时,出现不必要的空白区域或…...
代码随想录day38|| 322零钱兑换 279完全平方数 139单词拆分
322零钱兑换 力扣题目链接 题目描述: 给你一个整数数组 coins ,表示不同面额的硬币;以及一个整数 amount ,表示总金额。 计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一种硬币组合能组成总金额,…...
Cesium天空盒子(Skybox)制作(js代码)和显示
介绍 在Cesium中,星空背景是通过天空盒子方式(6张图片)来显示的,原生的图片分辨率太低,本项目用于生成天空盒子的6张图片。最终生成的6个图片大小约为500kb(每个),格式为jpg,总共的恒星数目约为…...
JAVA中的缓冲流BufferedInputStream
在Java中,BufferedInputStream 是一种用于包装其他输入流(如 FileInputStream)的过滤流。它通过内部缓冲区机制提高了输入流处理的效率。使用缓冲流可以减少读取数据的次数,因为每次从输入流读取数据时,BufferedInputS…...
WindowContainerTransaction类详解(一)
1、WindowContainerTransaction是什么: windowContainerTransaction类的对象是用来存储对windowContainer的修改的一个集合,windowContainer。因为应用侧是无法直接操作windowContainer的,如果应用侧需要修改windowContainer的话,…...
安装NFS扩展
#添加helm源 helm repo add nfs-subdir-external-provisioner https://kubernetes-sigs.github.io/nfs-subdir-external-provisioner #创建个namespace(可选,主要是为了查看资源方便) kubectl create ns nfs-sc-default #使用helm安装(10.1.129.86为NFS地址,/home/data/nfs…...
网络编程(Modbus进阶)
思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…...
Flask RESTful 示例
目录 1. 环境准备2. 安装依赖3. 修改main.py4. 运行应用5. API使用示例获取所有任务获取单个任务创建新任务更新任务删除任务 中文乱码问题: 下面创建一个简单的Flask RESTful API示例。首先,我们需要创建环境,安装必要的依赖,然后…...
Cesium1.95中高性能加载1500个点
一、基本方式: 图标使用.png比.svg性能要好 <template><div id"cesiumContainer"></div><div class"toolbar"><button id"resetButton">重新生成点</button><span id"countDisplay&qu…...
Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility
Cilium动手实验室: 精通之旅---20.Isovalent Enterprise for Cilium: Zero Trust Visibility 1. 实验室环境1.1 实验室环境1.2 小测试 2. The Endor System2.1 部署应用2.2 检查现有策略 3. Cilium 策略实体3.1 创建 allow-all 网络策略3.2 在 Hubble CLI 中验证网络策略源3.3 …...
【HTTP三个基础问题】
面试官您好!HTTP是超文本传输协议,是互联网上客户端和服务器之间传输超文本数据(比如文字、图片、音频、视频等)的核心协议,当前互联网应用最广泛的版本是HTTP1.1,它基于经典的C/S模型,也就是客…...
C++:多态机制详解
目录 一. 多态的概念 1.静态多态(编译时多态) 二.动态多态的定义及实现 1.多态的构成条件 2.虚函数 3.虚函数的重写/覆盖 4.虚函数重写的一些其他问题 1).协变 2).析构函数的重写 5.override 和 final关键字 1&#…...
QT开发技术【ffmpeg + QAudioOutput】音乐播放器
一、 介绍 使用ffmpeg 4.2.2 在数字化浪潮席卷全球的当下,音视频内容犹如璀璨繁星,点亮了人们的生活与工作。从短视频平台上令人捧腹的搞笑视频,到在线课堂中知识渊博的专家授课,再到影视平台上扣人心弦的高清大片,音…...
聚六亚甲基单胍盐酸盐市场深度解析:现状、挑战与机遇
根据 QYResearch 发布的市场报告显示,全球市场规模预计在 2031 年达到 9848 万美元,2025 - 2031 年期间年复合增长率(CAGR)为 3.7%。在竞争格局上,市场集中度较高,2024 年全球前十强厂商占据约 74.0% 的市场…...
负载均衡器》》LVS、Nginx、HAproxy 区别
虚拟主机 先4,后7...
Axure零基础跟我学:展开与收回
亲爱的小伙伴,如有帮助请订阅专栏!跟着老师每课一练,系统学习Axure交互设计课程! Axure产品经理精品视频课https://edu.csdn.net/course/detail/40420 课程主题:Axure菜单展开与收回 课程视频:...
