我写了一个端口扫描器,Rust再一次比Go慢,问题出在哪里呢?

💡 原文中文,约5200字,阅读约需13分钟。
📝

内容提要

本文探讨了使用Go和Rust编写TCP端口扫描器的性能差异。Go版本执行时间不到1秒,而Rust版本超过2秒。作者希望了解Rust性能较慢的原因,并尝试将Go代码迁移到Rust中,但在通道实现上遇到问题。此外,在高并发情况下,Rust和Go都无法扫描某些高端口。

🎯

关键要点

  • 本文探讨了使用Go和Rust编写TCP端口扫描器的性能差异。
  • Go版本执行时间不到1秒,而Rust版本超过2秒。
  • 作者希望了解Rust性能较慢的原因,并尝试将Go代码迁移到Rust中。
  • 在通道实现上遇到问题,tokio似乎只有oneshot和mpsc两种通道。
  • Rust版本在高并发情况下无法扫描某些高端口。
  • 作者的测试用例并不完全等价,Rust版本的并发数设定较高时速度更慢。
  • 在Rust中调整并发数到65535时,无法扫描到某些高端口。
  • Go语言如果直接给每个tcp链接起一个go程而不使用worker模式,也无法扫描到这些端口。

延伸问答

为什么Rust版本的TCP端口扫描器执行时间超过2秒?

Rust版本的执行时间较长,主要是由于并发数设定较高时速度更慢,以及在高并发情况下无法扫描某些高端口。

Go和Rust在TCP端口扫描器的性能差异是什么?

Go版本执行时间不到1秒,而Rust版本超过2秒,显示出Go在此任务上的性能优势。

在Rust中如何实现TCP端口扫描的并发?

Rust使用tokio库的异步特性,通过buffer_unordered方法控制并发,允许同时处理多个TCP连接。

Rust版本在高并发情况下无法扫描某些高端口的原因是什么?

当并发数调整到65535时,Rust版本无法扫描高端口,可能是由于系统资源限制或TCP连接的管理问题。

在将Go代码迁移到Rust时遇到的主要问题是什么?

主要问题是tokio库的通道实现,特别是mpsc通道无法满足代码迁移的需求,因为Receiver无法被clone。

如何优化Rust版本的TCP端口扫描器以提高性能?

可以尝试调整并发数和超时时间,避免达到某些阈值导致无法扫描高端口,同时优化TCP连接的管理。

➡️

继续阅读