一文理解Goland协程调度器scheduler的实现_第1页
一文理解Goland协程调度器scheduler的实现_第2页
一文理解Goland协程调度器scheduler的实现_第3页
一文理解Goland协程调度器scheduler的实现_第4页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第一文理解Goland协程调度器scheduler的实现目录1.调度器scheduler的作用2.GMP模型3.调度机制

1.调度器scheduler的作用

我们都知道,在Go语言中,程序运行的最小单元是gorouines。

然而程序的运行最终都是要交给操作系统来执行的,以Java为例,Java中的一个线程对应的就是操作系统中的线程,以此来实现在操作系统中的运行。在Go中,gorouines比线程更轻量级,其与操作系统的线程也不是一一对应的关系,然而,最终我们想要执行程序,还是要借助操作系统的线程来完成,调度器scheduler的工作就是完成gorouines到操作系统线程的调度。

2.GMP模型

当我们运行gofun(){}时,会生成一个g,优先放置在创建他的p的本地队列中,如果本地队列已满,那么会放置在全局队列中。

g的运行需要借助p与m,p是执行器,只有获得p的g才能执行,p的执行需要挂在m上,m对应的是操作系统中的线程,p的数量与CPU的核数相同。

goroutine运行所需要的上下文信息都是存放在g的数据结构当中的,所以g可以依靠任意的p或者m执行,而对于操作系统而言,其并不能看到p与g的调度过程,这些过程对于操作系统线程来说都是连续的,所以省去了线程上下文切换的开销。

g的数据结构如下所示:

typegstruct{

stackstack//g自己的栈

m*m//执行当前g的m

schedgobuf//保存了g的现场,goroutine切换时通过它来恢复

atomicstatusuint32//g的状态Gidle,Grunnable,Grunning,Gsyscall,Gwaiting,Gdead

goidint64

schedlinkguintptr//下一个g,g链表

preemptbool//抢占标记

lockedmmuintptr//锁定的M,g中断恢复指定M执行

gopcuintptr//创建该goroutine的指令地址

startpcuintptr//goroutine函数的指令地址

}

p的数据结构如下所示:

typepstruct{

idint32

statusuint32//状态

linkpuintptr//下一个P,P链表

mmuintptr//拥有这个P的M

mcache*mcache

//P本地runnable状态的G队列

runqheaduint32

runqtailuint32

runq[256]guintptr

runnextguintptr//一个比runq优先级更高的runnableG

//状态为dead的G链表,在获取G时会从这里面获取

gFreestruct{

gList

nint32

gcBgMarkWorkerguintptr//(atomic)

gcwgcWork

}

m的数据结构如下所示:

typemstruct{

g0*g//g0,每个M都有自己独有的g0

curg*g//当前正在运行的g

ppuintptr//当前用于的p

nextppuintptr//当m被唤醒时,首先拥有这个p

idint64

spinningbool//是否处于自旋

parknote

alllink*m//onallm

schedlinkmuintptr//下一个m,m链表

mcache*mcache//内存分配

lockedgguintptr//和G的lockedm对应

freelink*m//onsched.freem

}

通过gmp模型,我们能解决gorouines到操作系统线程的映射问题,gorouines之间的切换是在用户态完成的,在操作系统的视角来看,线程的上下文切换并不频繁,因此就少了很多陷入内核的过程,所以有更好的并发效果。

3.调度机制

1)workstealing机制

当一个p上的g执行完之后,他会尝试从其他的p队列中窃取g来执行,以减少操作系统线程的切换动作。

2)hand

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论