性能比拼: Rust vs C++

本内容是对知名性能评测博主 Anton Putra 1个月前 Rust vs C++ Performance 内容的翻译与整理, 有适当删减, 相关指标和结论以原作为准

介绍

在本视频中,将对比 RustC++

会使用 Axum 框架的一个稍微改进的版本,该框架基于 HyperTokio 运行时,而对于 C++ ,我会使用 Drogon框架

我们将测量两款应用的 延迟(latency)吞吐量(throughput) ,以及 CPU 和内存使用情况(CPU & memory usage)

AWS 上运行测试,每个应用都部署在 m7a.large 实例上,该实例配备 2 个 CPU 和 8GB 内存

此外,我还设置了相同数量的线程,每个应用均使用 2 个线程,如你可以在终端中看到的那样。


测试

好了,我们现在来运行测试。

整个基准测试持续了 大约 2 小时 ,但(剪辑视频时)我将其压缩到了仅 几分钟

另外,如果你能对正在测试的应用进行优化,请提交 PR (Pull Request),我会 尽快合并重新运行测试

同时,我也需要大家的帮助,为 C++ 应用 添加额外的功能。

在测试的前半程,我注意到 两者的延迟表现非常接近,这在 Web 框架中是很少见的。

好了,我再运行 1 分钟,然后逐一分析每个图表。


结果分析

1. 吞吐量(Throughput)

C++ 仅达到 142,000 请求/秒

改进后的 Axum 达到了 176,000 请求/秒

这次 Rust 表现更好 ,相比于之前 Rust vs. Go 的基准测试有所提升,

主要原因是:

  • 这次使用了 更小的负载(payload)
  • 我接受了一些 PR,提升了整体性能。

2. 延迟(Latency)

Rust 也在延迟方面表现更优

更低的延迟 始终是更好的,特别是对于 面向客户端的应用 来说。

3. CPU 使用情况(CPU Usage)

4. 内存使用情况(Memory Usage)


结论

这一次,Rust 的整体表现优于 C++

但我希望能收到更多 PR ,进一步优化 C++ 的性能

并为其 添加更多功能

只是第一轮测试 ,接下来的 第二轮测试 将会包含:

  • 数据库测试
  • 可能会增加更多使用场景
相关推荐
码事漫谈5 小时前
智能体颠覆教育行业调研报告:英语、编程、语文、数学学科应用分析
后端
蓝-萧5 小时前
使用Docker构建Node.js应用的详细指南
java·后端
码事漫谈5 小时前
《C语言点滴》——笑着入门,扎实成长
后端
Tony Bai6 小时前
【Go模块构建与依赖管理】09 企业级实践:私有仓库与私有 Proxy
开发语言·后端·golang
咖啡教室6 小时前
每日一个计算机小知识:ICMP
后端·网络协议
间彧6 小时前
OpenStack在混合云架构中通常扮演什么角色?
后端
咖啡教室6 小时前
每日一个计算机小知识:IGMP
后端·网络协议
间彧6 小时前
云原生技术栈中的核心组件(如Kubernetes、Docker)具体是如何协同工作的?
后端
清空mega6 小时前
从零开始搭建 flask 博客实验(3)
后端·python·flask
努力的小郑7 小时前
Elasticsearch 避坑指南:我在项目中总结的 14 条实用经验
后端·elasticsearch·性能优化