Go线程实现模型-P

news2024/11/17 8:45:10

P

概述

P是G能够在M中运行关键。Go的运行时系统会适时地让P与不同的M建立或断开关联,以使P中的那些可运行的G能够及时获得,这与操作系统内核在CPU之上实时切换不同进程或线程的情况类似

改变P的数量

改变单个Go程序间拥有的P的最大数量有两种方法

  • 调用函数runtime.GoMAXRPOCS并把想要设定的数量作为参数传入
  • 在Go程序运行前设置环境变量GOMAXPROCS的值(硬性上限值256)

P的最大数量实际上是对程序中并发运行的G的规模的现实。P的数量即为可运行G的队列的数量。

一个G在被启用后,会先被追加到某个P的可运行G队列中,以等待时机。一个P只有与一个M关联在一起,才会使其可运行G队列中的G有机会运行

不过,设置P的最大数量只能限制住P的数量,而对G和M的数量没有任何约束。

使用了runtime.GoMAXRPOCS后,会暂时使P都脱离运行状态,并试图阻止任何用户级别的G的运行。只有在新P最大值设定完成后,运行时系统才会开始陆续恢复它们

M阻塞时,P的状况

当M因系统调用而阻塞(运行的G进入了系统调用)的时候,运行时系统会把该M和与之关联的P分离出来

这时,如果这个P的可运行G队列中还没有未被运行的G,那么运行时系统就会找到一个空闲M,或创建一个新的M,并与该P关联以满足这些G的运行需要

因此,M的数量在很多时候也都会比P多。而G的数量,一般取决于Go程序本身

重整P

在确定P最大数量之后,运行时系统会根据这个数值重整全局的P列表(runtime.allp)。与全局M列表类似,该列表中包含了当前运行时系统创建的所有P

运行时系统会把这些P中的可运行G全部取出,并放入调度器的可运行G队列中。被转移的那些G,会在以后经由调度再次放入某个P的可运行G队列

空闲P列表

与空闲M列表类似,运行时系统中也存在一个调度器的空闲P列表(runtime.sched.pidle)。当一个P不再与任何M关联的时候,运行时系统会把放入该列表

而当运行时系统需要一个空闲的P关联某个M的话,会从此列表中取出一个。注意,P进入空闲P列表的一个前提是它的可运行G列表必须为空

例如,在重整全局P列表的时候,P在被清空可运行G队列之后,才会被放入空闲P列表

P的状态转换

P的状态

Pidle: 此状态表明当前P未与任何M存在关联

Prunning: 此状态表明当前P正在与某个M关联

Psyscall: 此状态表明当前P中的运行的那个G正在进行系统调用

Pgcstop: 此状态表明运行时系统需要停止调度。例如运行时系统在开始垃圾回收的某些步骤前,就会试图把全局P列表中的所有P都置于这个状态

状态转换

在这里插入图片描述

P 创建之初的状态是Pgcstop,虽然这并不意味这时进行垃圾回收。不过,P处于这一初始状态的时间非常短暂

初始化之后,运行时系统会将其状态设置为pidle,并放入调度器的空闲P列表

图中可见,非Pdead状态的P都会在运行时系统欲停止调度时被置于Pgcstop状态,然后统一转换为Pidle状态,并公平地接受再次调度

另一方面,非Pgcstop状态的P都可能因全局P列表的缩小而被认为是多余的,并被置于Pdead状态。同时P被转换为Pdead前,其可运行G队列的G都会转移到调度器的可运行G队列,而它的自由G列表中的G也都会被转移到调度器的自由G列表中

自由G列表

每个P中除了都有一个可运行G队列外,还都包含一个自由G列表,这个列表中包含了一些已经运行完成的G

随着运行完成的G的增多,该列表可能会很长。如果它增长到一定程度,运行时系统就会把其中的部分G转移到调度器的自由G列表中

另一方面,当使用go语句欲启用一个G的时候,运行时系统会试图从相应P的自由G列表中获取一个现成的G,来封装这个go语句携带的函数,仅当获取不到一个G的时候才有可能创建一个新的G

考虑到由于相应P的自由G列表为空获取不到自由G的情况,运行时系统会在发现其中的自由G太少时,预先尝试从调度器的自由G列表中转移过来一些G。如此一来,只有在调度器的自由G列表也弹尽粮绝的时,才会有新的G被创建。这在很大程度上提高了G的复用率

总结

在P的结构中,可运行G队列和自由G列表最重要的两个成员。至少对于Go语言的是这样,它们间接地体现了运行时系统对G的调度情况

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1882931.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

《塔瑞斯世界》国服震撼登场!AOC助力玩家开启游戏新征途!

一款真正高画质、重机制、轻数值的MMORPG大作! 你是否厌倦了在MMORPG游戏中被“氪金大佬”碾压?你是否渴望一个纯粹依靠技术和策略就能获得成就感的游戏世界?如果你对这两个问题的答案都是肯定的,那么《塔瑞斯世界》或许值得你一…

docker-compose搭建minio对象存储服务器

docker-compose搭建minio对象存储服务器 最近想使用oss对象存储进行用户图片上传的管理,了解了一下例如aliyun或者腾讯云的oss对象存储服务,但是呢涉及到对象存储以及经费有限的缘故,决定自己手动搭建一个oss对象存储服务器; 首先…

前端git约定式规范化提交-commitizen

当使用commitizen进行代码提交时,commitizen会提示你在提交代码时填写所必填的提交字段信息内容。 1、全局安装commitizen npm install -g commitizen4.2.4 2、安装并配置 cz-customizeable 插件 2.1 使用 npm 下载 cz-customizeable npm i cz-customizeable6.…

30秒就能完成3D翻页画册的工具

​在数字化时代,将传统画册转化为电子版,并赋予其3D翻页的动态效果,不仅能够增强视觉效果,还能提高资料的传播效率。对于需要在短时间内完成3D翻页画册制作的用户,这里推荐一款能迅速实现这一目标的在线工具。 首先&am…

Web3 游戏周报(6.23 - 6.29)

区块链游戏热度不减,你是否掌握了上周的重要动态? 回顾上周区块链游戏动态,查看 Footprint Analytics 与 ABGA 的最新数据报告。 【6.23 - 6.29】Web3 游戏行业动态: 继 Notcoin 之后,另一款 Telegram 游戏 Hamster …

沙箱在“一机两用”新规下的价值体现

在数字化时代,随着企业信息化建设的深入,数据安全问题愈发凸显其重要性。一机两用新规的出台,旨在通过技术创新和管理手段,实现终端设备的安全可控,确保敏感数据的安全存储与传输。SDC沙箱技术作为一种创新的安全防护手…

期权交易指南:为什么要交易场外个股期权?

今天带你了解期权交易指南:为什么要交易场外个股期权?随着金融市场的发展和创新,投资者寻求更多的工具来管理风险和获得更高的回报。场外期权交易应运而生,成为一种重要的金融衍生品交易方式。 简单来说就是期权是一种合约&#…

如何用程序批量下载小红书的图片?

如何使用MediaCrawler快速下载图片 作为一名图像算法工程师,怎么能没有图片资源呢?今天,我要介绍一个能快速下载图片的方法,仅供学习使用,请勿用于其他用途。 下载项目 首先,从GitHub下载项目&#xff1…

fastapi swagger在线接口文档报错

fastapi swagger在线接口文档报错 1、报错信息 Unable to render this definition The provided definition does not specify a valid version field. Please indicate a valid Swagger or OpenAPI version field. Supported version fields are swagger: “2.0” and those …

无线领夹麦克风哪个品牌音质最好,直播用领夹麦克风还是声卡麦

随着社交媒体的兴起,直播和Vlog已经成为内容创作的新趋势,这些变化不仅改变了人们分享生活的方式,也带动了音频设备市场的增长。无线领夹麦克风,以其便携性和卓越的录音品质,迅速成为视频制作者的重要工具。它们在直播…

<电力行业> - 《第11课:配电(1)》

1 配电 配电(power distribution)是在电力系统中直接与用户相连并向用户分配电能的环节。配电系统由配电变电所、高压配电线路、配电变压器、低压配电线路以及相应的控制保护设备组成。 1.1 概念 配电系统是由多种配电设备(或元件&#xf…

昂科烧录器支持BPS晶丰明源半导体的多相Buck控制器BPD93004E

芯片烧录行业领导者-昂科技术近日发布最新的烧录软件更新及新增支持的芯片型号列表,其中BPS晶丰明源半导体的多相Buck控制器BPD93004E已经被昂科的通用烧录平台AP8000所支持。 BPD93004E是一款多相Buck控制器,支持原生1~4相,数字方式控制&am…

经典的卷积神经网络模型 - AlexNet

经典的卷积神经网络模型 - AlexNet flyfish AlexNet 是由 Alex Krizhevsky、Ilya Sutskever 和 Geoffrey Hinton 在 2012 年提出的一个深度卷积神经网络模型,在 ILSVRC-2012(ImageNet Large Scale Visual Recognition Challenge 2012)竞赛中…

Domino应用中的HTML5

大家好,才是真的好。 在xpages多年不见有效更新,前景不明的时候,Domino传统Web应用开发方式还是受到了应有的青睐。毕竟,在Nomad Web时代,连最传统的Notes CS原生应用也突然焕发了勃勃生机一样。 但,对有…

51单片机嵌入式开发:STC89C52环境配置到点亮LED

STC89C52环境配置到点亮LED 1 环境配置1.1 硬件环境1.2 编译环境1.3 烧录环境 2 工程配置2.1 工程框架2.2 工程创建2.3 参数配置 3 点亮一个LED3.1 原理图解读3.2 代码配置3.3 演示 4 总结 1 环境配置 1.1 硬件环境 硬件环境采用“华晴电子”的MINIEL-89C开发板,这…

你还不会买智能猫砂盆吗?跟你们详细讲解今年最火的智能猫砂盆!

智能猫砂盆的坑,想必有很多养猫家庭都踩过吧。自己买回来的机器,不是空间不够大,导致猫咪拉到外面去,就是铲不干净,还得自己进行二次清理,搞得这个智能猫砂盆白买了。那如果我们想要购买合适自己家猫咪的智…

MyBatisPlus 基础数据表的增删改查 入门 简单查询

MyBatisPlus MyBatisPlus(简称MP)是一个基于MyBatis的增强工具库,简化了MyBatis的开发,提供了很多实用的功能和特性,如自动生成SQL、通用CRUD操作、分页插件、条件构造器、代码生成器等。它不仅简化了开发过程&#x…

Objective-C语法基础

新建一个XCode项目 新建一个类 1、成员变量、属性 1.1、类内使用成员变量&#xff0c;类外使用属性 Role.h #import <Foundation/Foundation.h>NS_ASSUME_NONNULL_BEGINinterface Role : NSObject {//成员变量&#xff1a;只能类内使用NSString *_name;int _age; }//属…

二次封装 el-dialog 实现 全屏和最小化 功能

效果 封装后的组件 <template><el-dialog v-model"dialogVisible" :show-close"false" :fullscreen"fullscreen" draggable overflow><template #header"{ close }"><div><span style"font-weight: b…

ts语法---数据类型,interface和type的用法

ts的数据类型 ts的数据类型自上而下的分级有 第一层 any-任意类型和unknow类型&#xff0c; 第二层 原型链的Object类型&#xff0c; 第三层 js类的类型 第四层 标准的typescript类型 第五层 对应的实例数据类型 第六层 never类型&#xff0c;never表示不合理&#xff0c…