登录
首页 >  Golang >  Go问答

是否可以强制 go 例程在特定 CPU 上运行?

来源:Golang技术栈

时间:2023-04-12 15:05:00 283浏览 收藏

亲爱的编程学习爱好者,如果你点开了这篇文章,说明你对《是否可以强制 go 例程在特定 CPU 上运行?》很感兴趣。本篇文章就来给大家详细解析一下,主要介绍一下golang,希望所有认真读完的童鞋们,都有实质性的提高。

问题内容

我正在阅读有关 go 包“运行时”的信息,并看到我可以在其他 (func GOMAXPROCS(n int)) 中设置可用于运行我的程序的 CPU 单元的数量。我可以强制 goroutine 在我选择的特定 CPU 上运行吗?

正确答案

在现代 Go 中,为了提高效率,我不会将 goroutine 锁定到线程。Go 1.5添加了 goroutine 调度亲和性,以最小化 goroutine 在 OS 线程之间切换的频率。CPU 之间剩余迁移的任何成本都必须与用户模式调度程序避免上下文切换到内核模式的好处进行权衡。最后,当切换成本是一个真正的问题时,有时更好的重点是改变你的程序逻辑,这样它就需要更少的切换,比如通过通信批量工作而不是单个工作项。

但即使考虑到所有这些,有时你只需要锁定一个 goroutine,比如当 C API 需要它时,我会假设下面是这种情况。


如果整个程序使用 运行GOMAXPROCS=1,那么[通过调用 schedutils 包中的任务集实用程序来设置 CPU 亲和性相对简单](http://www.cyberciti.biz/tips/setting-processor-affinity-certain- task-or-process.html)。

GOMAXPROCS > 1如果因为goroutines 在运行时在 OS 线程之间迁移,我原以为你不走运。事实上,James Henstridge 指出你可以使用它 runtime.LockOSThread()来防止你的 goroutine 迁移。不过,一旦您将 goroutine 锁定到它,我不知道有任何 Go stdlib 函数来设置当前线程的 CPU 亲和性。您也许可以使用 cgo 和 call [pthread_setaffinity_np](http://man7.org/linux/man- pages/man3/pthread_getaffinity_np.3.html),因为显然[Go 在 cgo 模式下使用 pthreads](https://groups.google.com/d/msg/golang- nuts/H9QbEVrzccc/-sWAyHyBDj0J)。由于我们谈论的是系统调用,因此细节会因操作系统而异。

(如果你的整个程序是纯 Go(没有 C 链接),它可能会通过模块[sched_setaffinity](http://man7.org/linux/man- pages/man2/sched_setaffinity.2.html)使用零pid参数调用syscall。但这会很棘手。)

本篇关于《是否可以强制 go 例程在特定 CPU 上运行?》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

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