关于go协程池的疑问

fichtner · · 1713 次点击
使用GODEBUG进行分析。 比如`GODEBUG="schedtrace=1000" go test` `GODEBUG="scheddetail=1,schedtrace=1000" go test` 你会发现使用sleep时,调度压力其实很低的。每个P每次采样时,调度的协程数比较少。sleep期间不需要p去分配时间片。而调用testFunc时,一直在用cpu计算。所以P对协程的调度压力很大。超过一定量后协程,协程的调度损耗就体现出来了。这时候用线程池,限制数量,反而降低了调度损耗。
#10
更多评论
Go的协程那么简单好用,还用的着什么Ants协程池么?直接创建协程,然后通过channel传递数据,在协程中处理即可,这种方式是语言级别推荐,效率应该也是最高的。
#1
协程池一方面是为了控制资源占用,另一方面在特定情况下提高效率,这种提高主要体现在复用。比如避免新开的协程经常发生栈扩展等。因为创建协程相比创建线程代价低太多,所以相比线程池,在这一方面不见得有提升。在硬件条件充足时,新建协程速度更快很正常。使用协程池,工作协程数量少,反而处理慢。 但看文章内容,可变因素多不好判定。建议协程池通过压测测试最合适的工作协程数量,以及最高内存占用。再做统一资源限制后(比如限制内存使用),测试不使用协程的情况。
#2