登录
首页 >  Golang >  Go问答

加速 Go 中的系统调用

来源:stackoverflow

时间:2024-04-07 16:30:37 480浏览 收藏

学习知识要善于思考,思考,再思考!今天golang学习网小编就给大家带来《加速 Go 中的系统调用》,以下内容主要包含等知识点,如果你正在学习或准备学习Golang,就都不要错过本文啦~让我们一起来看看吧,能帮助到你就更好了!

问题内容

我一直在研究用 go 编写的 vpn,并开始尝试优化数据流。粗略地看,实现代码似乎很合理,因为不存在内存泄漏问题,而且 CPU 似乎也不是一个限制。

所以我转向了 pprof,我看到的问题是大部分执行时间都花在 syscall.Syscall 上。我对正在运行的 iperf 吞吐量测试进行了 6 秒的配置文件,这就是我所看到的:

此测试在 docker 容器内的客户端和服务器上运行,客户端获取到服务器的 --link。在基础桥接网络上运行 iperf 会产生大约 40Gbit 的吞吐量,而在此 vpn impl 上运行 iperf 会产生大约 500Mbit 的吞吐量。

一个简单的 htop 显示 3/4 的时间花在系统上。

我尝试了几种方法来尝试加快单客户端的速度,但我似乎找不到一种方法来减轻在 VPN 服务器中写入数据包的速度...注意:iperf 使用完整的 MTU 大小的数据包在测试过程中限制了一些明显的优化。

列出系统调用:

不知道为什么这显示 CMPQ 一直占用时间,我认为这应该归因于 SYSCALL。


解决方案


pprof 是一个进程采样分析器。它发现程序计数器(PC)经常在操作系统执行时等待CMPQ执行。

您可以减少 SYSCALL 的频率。您可以改进OS SYSCALL 机制。您可以改进要求 SYSCALL 执行的操作系统代码。您可以使用更好的硬件。等等。

今天带大家了解了的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>