深入理解golang的GMP模型

Go以其高效的并发模型而闻名,这主要取决于它的调度器设计。Go的调度器采用了GMP模型,即Goroutine、Machine和Processor的缩写。

1.GMP概述

GMP模型是Go语言在运行时系统的核心组成部分,负责管理和调度Goroutine的执行。

它的三个主要组件:

Goroutine(G):Goroutine是Go语言中的轻量级线程,由Go运行时管理。Goroutine的创建和销毁开销远小于操作系统线程,因此Go程序可以轻松创建成千上万个Goroutine。

Machine(M):Machine代表操作系统线程,它是真正执行Goroutine的实体,每个M都与操作系统线程绑定,负责执行Goroutine的代码。

Processor(P):Processor是Go运行时中的逻辑处理器,它负责管理Goroutine的调度。每个P都有一个本地Goroutine队列,用于存储等待执行的Goroutine。

2.GMP模型的工作原理

(1)Goroutine的创建与调度

当一个Goroutine被创建时,它会被放入一个全局队列或者某个P的本地队列中。Go运行时会根据一定的策略将Goroutine分配给空闲的P执行。

(2)Processor的作用

每个P都有一个本地Goroutine队列,用于存储等待执行的Goroutine。P会从LRQ(本地Goroutine队列)中取出Goroutine并将其分配给与之绑定的M执行。如果LRQ为空,P会尝试从GRQ中获取Goroutine,或者从其他P的LRQ中"偷取"Goroutine来执行。

(3)Machine的执行

M是真正执行Goroutine的实体。每个M都与一个操作系统线程绑定,负责执行Goroutine的代码。当M执行完一个Goroutine后,它会继续从与之绑定的P的LRQ中获取下一个Goroutine执行。

(4)调度器的负载均衡

Go的调度器会动态调整P的数量,以充分利用多核CPU的计算能力。当某个P的LRQ中的Goroutine过多时,调度器会将部分Goroutine迁移到其他P的LRQ中,以实现负载均衡。

3.GMP的优势

(1)高效的Goroutine调度

GMP模型通过将Goroutine分配到多个P上执行,充分利用了多核CPU的并行计算能力。同时,P的本地队列减少了Goroutine调度的竞争,提高了调度效率。

(2)低开销的Goroutine切换

由于Goroutin是轻量级线程,其切换开销远小于操作系统线程的切换开销。GMP模型通过操作线程的绑定,实现了Goroutine的高效切换。

(3)动态负载均衡

Go的调度器能够动态调整P的数量,并根据负载情况将Goroutine迁移到其他P上执行,从而实现了系统的动态负载均衡。

4.GMP模型的缺点

当Goroutine数量过多时,调度器的负载均衡机制可能会导致频繁的Goroutine迁移,从而增加系统的开销。

相关推荐
季明洵17 小时前
C语言实现单链表
c语言·开发语言·数据结构·算法·链表
小小张说故事17 小时前
BeautifulSoup:Python网页解析的优雅利器
后端·爬虫·python
墨雪不会编程17 小时前
C++之【深入理解Vector】三部曲最终章
开发语言·c++
怒放吧德德17 小时前
后端 Mock 实战:Spring Boot 3 实现入站 & 出站接口模拟
java·后端·设计
浅念-17 小时前
C语言编译与链接全流程:从源码到可执行程序的幕后之旅
c语言·开发语言·数据结构·经验分享·笔记·学习·算法
biyezuopinvip17 小时前
基于Spring Boot的企业网盘的设计与实现(任务书)
java·spring boot·后端·vue·ssm·任务书·企业网盘的设计与实现
UrbanJazzerati17 小时前
Python编程基础:类(class)和构造函数
后端·面试
小宋102117 小时前
Java 项目结构 vs Python 项目结构:如何快速搭一个可跑项目
java·开发语言·python
楚兴18 小时前
MacBook M1 安装 OpenClaw 完整指南
人工智能·后端
一晌小贪欢18 小时前
Python 爬虫进阶:如何利用反射机制破解常见反爬策略
开发语言·爬虫·python·python爬虫·数据爬虫·爬虫python