首页  >  文章  >  后端开发  >  Go 调度程序何时以及为何分配新的 M 和 P 处理器?

Go 调度程序何时以及为何分配新的 M 和 P 处理器?

Linda Hamilton
Linda Hamilton原创
2024-10-30 17:36:03894浏览

When and Why Does the Go Scheduler Allocate New M and P Processors?

Go 调度程序何时以及为何分配新的 M 和 P 处理器

了解 Go 运行时的调度模型对于优化应用程序性能至关重要。该模型的一个关键方面是 M(机器)和 P(处理器)的分配。

何时创建 M 和 P?

M 处理器在何时创建:

  • 启动一个新的 goroutine(除非有空闲的 M)
  • 现有的 M 阻塞在 A 系统调用上(创建一个新的操作系统线程,称为 M )

P 处理器是在所有本地运行队列已满时创建的,一个 goroutine 正在运行,其邻居 goroutine 准备好运行被放入全局队列中,并且它包含一个 p。

阻塞任务和 P 重用

在提供的测试代码中,goroutine 执行阻塞数据库操作。阻塞任务会从 P 个处理器中移除 M 个处理器。

在这种情况下,需要创建新的 M 个处理器来处理阻塞的 goroutine。最初的 8 个(虚拟核心数量)M 个处理器对于第二批来说是不够的。新的 M 个处理器将根据需要分配。

其他资源

  • https://www.programmersought.com/article/795578​​85527/
  • https://blog.golang.org/go-goroutine-os-thread-and-cpu-management

以上是Go 调度程序何时以及为何分配新的 M 和 P 处理器?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn