给 Web Server 加压力, CPU 火焰图显示 50% 消耗在 runtime 上,是什么原因?

2018-01-23 13:07:37 +08:00
 mornlight
用 gin 新写好的一个服务端,正常流量时没有啥问题,做压力测试,对某个高频业务接口调用 15000 次 /秒,go-torch 拿出来 60 秒的火焰图,发现一半消耗在业务逻辑上(主要是读写 Redis 和 JSON 序列化),另一半消耗在 Go 自己的 runtime 里。
机器环境:32 核物理 CPU,Docker 限制 1200% CPU 使用,被占满。

想请教各位这个 runtime.findrunnable 消耗是 goroutine 数量上去后带来的还是 CPU 不够用带来的?是否有办法避免或缓解?
2671 次点击
所在节点    Go 编程语言
22 条回复
admirez
2018-02-10 10:11:55 +08:00
@mornlight 楼主还等着你的结果呢……
mornlight
2018-02-11 09:18:53 +08:00
@admirez #21 我在服务器上拿来跑测试的 docker 不知道被谁删了,还没有做更多的测试。你想要啥结果呢?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/425208

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX