全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Go Goroutine 调度深度解析:理解并发与并行执行的差异

本文深入探讨 go 语言中 goroutine 的调度机制,解释为何在多 goroutine 场景下,实际的并行执行行为可能与预期不符。我们将阐明 go 运行时调度器的工作原理,特别是 gomaxprocs 参数对并发与并行执行的影响,并提供实践建议以实现更有效的并行处理。

1. Goroutine 与 Go 并发模型概述

Go 语言通过 Goroutine 提供了一种轻量级的并发机制。Goroutine 是由 Go 运行时管理的协程,相比传统的操作系统线程,它具有更小的内存开销和更快的创建、切换速度。当使用 go 关键字启动一个函数时,它就会在一个新的 Goroutine 中异步执行。

理解 Go 的并发模型,首先要区分“并发”(Concurrency)和“并行”(Parallelism):

  • 并发:指能够同时处理多个任务的能力,即使这些任务并非在同一时刻执行。它们可能在单个处理器核心上通过时间片轮转的方式交替执行。
  • 并行:指多个任务在多个处理器核心上真正地同时、同步执行。

Go 语言天生支持并发,但要实现真正的并行则需要满足一定的条件。

2. Go 运行时调度器的工作原理

Go 运行时包含一个复杂的调度器,负责将 Goroutine 映射到操作系统线程上执行。这个调度器采用了 M:N 调度模型,即 N 个 Goroutine 可以在 M 个操作系统线程上运行。其核心组件包括:

  • G (Goroutine):Go 应用程序中的并发执行单元。
  • M (Machine/OS Thread):操作系统线程,是实际执行代码的载体。
  • P (Processor):逻辑处理器,代表一个 Go 运行时上下文,它将 G 绑定到 M 上。每个 P 维护一个本地的 Goroutine 队列,当 M 完成当前 G 的执行后,会从 P 的队列中取出下一个 G 执行。当 P 的本地队列为空时,它会尝试从其他 P 的队列中“偷取” Goroutine。

2.1 GOMAXPROCS 的作用

GOMAXPROCS 是一个环境变量,也可以通过 runtime.GOMAXPROCS 函数在程序中设置。它控制了 Go 运行时可以同时使用的逻辑处理器 P 的数量。

  • 默认值:在 Go 1.5 版本及之后,GOMAXPROCS 的默认值通常设置为机器的 CPU 核心数 (runtime.NumCPU())。但在更早的版本中或某些特定环境下,其默认值可能为 1。
  • GOMAXPROCS = 1 的影响:当 GOMAXPROCS 设置为 1 时,即使系统拥有多个 CPU 核心,Go 运行时也只会创建一个逻辑处理器 P。这意味着所有 Goroutine 都必须在一个操作系统线程(M)上轮流执行。在这种情况下,Goroutine 之间只能实现并发,而无法实现真正的并行执行。它们会分时共享 CPU 资源,表现为交替执行。
  • GOMAXPROCS > 1 的影响:当 GOMAXPROCS 设置为大于 1 的值时,Go 运行时会创建相应数量的逻辑处理器 P。这些 P 可以被多个操作系统线程 M 使用,从而允许 Goroutine 在多个 CPU 核心上同时执行,实现并行。

3. 实验现象分析:为何并行执行不如预期?

在提供的实验代码中,用户启动了两个计算密集型(CPU 密集型)的 Goroutine,每个 Goroutine 都重复调用 fib 函数。观察到的现象是,在大部分时间内,两个 Goroutine 都是以大块的形式交替执行,而不是预期的“并排”或细粒度交错执行,直到任务后期才出现更频繁的切换。

这种现象通常是 GOMAXPROCS 默认值为 1 时的一个典型表现。当 GOMAXPROCS=1 时:

  1. 单线程执行:Go 运行时只有一个逻辑处理器 P,所有 Goroutine 都在这一个 P 绑定的 M(操作系统线程)上执行。
  2. 长时间占用 CPU:fib 函数是一个纯粹的 CPU 密集型计算,它不会主动进行 I/O 操作,也不会调用 runtime.Gosched() 等函数来主动让出 CPU。这意味着一个 Goroutine 一旦开始执行 fib 计算,它会尽可能长时间地占用 CPU,直到被 Go 调度器强制抢占(preemption)。
  3. 抢占式调度:Go 调度器在 Goroutine 运行时会定期进行抢占检查。在 Go 1.14 之前,抢占主要发生在函数调用或循环的后向跳转点。从 Go 1.14 开始,Go 引入了非协作式抢占(asynchronous preemption),使得调度器可以在任意安全点抢占 Goroutine。然而,即使有了抢占,对于长时间运行的 CPU 密集型任务,调度器也可能允许一个 Goroutine 运行相当长一段时间,直到达到抢占点或时间片耗尽。
  4. “后期交错”现象:至于为何在任务后期出现更频繁的交错,这可能与 fib 函数在计算较大数字时所需的执行时间有关,或者仅仅是调度器在特定时刻的决策。调度器的行为是非确定性的,它会根据内部启发式算法和系统负载来决定何时切换 Goroutine。在 CPU 密集型任务中,如果一个 Goroutine 不主动让出 CPU,调度器倾向于让它运行一段时间,以减少上下文切换的开销。

4. 实现真正的并行执行

要让 Goroutine 在多核 CPU 上实现真正的并行执行,关键在于确保 Go 运行时能够利用多个逻辑处理器 P。最直接的方法是设置 GOMAXPROCS。

4.1 设置 GOMAXPROCS

你可以通过以下两种方式设置 GOMAXPROCS:

  • 通过代码设置 (推荐): 在 main 函数的开头调用 runtime.GOMAXPROCS 函数。通常,我们会将其设置为机器的 CPU 核心数,以充分利用硬件资源。

    package main
    
    import (
        "fmt"
        "runtime"
        "sync" // 用于等待 Goroutine 完成
    )
    
    // fib 计算第 n 个斐波那


# go  # 操作系统  # 处理器  # mac  # ai  # 环境变量  # 循环  # 线程  # Thread  # 并发  # 异步  # 算法  # 多个  # 设置为  # 长时间  # 是一个  # 它会  # 默认值  # 后期  # 多核  # 能与 


相关文章: 建站VPS能否同时实现高效与安全翻墙?  建站之星安装后如何配置SEO及设计样式?  如何在Tomcat中配置并部署网站项目?  头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?  实例解析Array和String方法  建站之星后台密码遗忘如何找回?  专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?  武汉网站制作费用多少,在武汉武昌,建面100平方左右的房子,想装暖气片,费用大概是多少啊?  相亲简历制作网站推荐大全,新相亲大会主持人小萍萍资料?  寿县云建站:智能SEO优化与多行业模板快速上线指南  网站制作的步骤包括,正确网址格式怎么写?  如何生成腾讯云建站专用兑换码?  简单实现Android文件上传  西安大型网站制作公司,西安招聘网站最好的是哪个?  制作企业网站建设方案,怎样建设一个公司网站?  单页制作网站有哪些,朋友给我发了一个单页网站,我应该怎么修改才能把他变成自己的呢,请求高手指点迷津?  如何快速重置建站主机并恢复默认配置?  建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析  在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  我的世界制作壁纸网站下载,手机怎么换我的世界壁纸?  建站之星24小时客服电话如何获取?  怎么将XML数据可视化 D3.js加载XML  宠物网站制作html代码,有没有专门介绍宠物如何养的网站啊?  如何快速搭建虚拟主机网站?新手必看指南  弹幕视频网站制作教程下载,弹幕视频网站是什么意思?  ppt制作免费网站有哪些,ppt模板免费下载网站?  网页设计与网站制作内容,怎样注册网站?  建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析  怀化网站制作公司,怀化新生儿上户网上办理流程?  如何续费美橙建站之星域名及服务?  建站主机数据库如何配置才能提升网站性能?  制作销售网站教学视频,销售网站有哪些?  外贸公司网站制作,外贸网站建设一般有哪些步骤?  高端网站建设与定制开发一站式解决方案 中企动力  制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?  道歉网站制作流程,世纪佳缘致歉小吴事件,相亲网站身份信息伪造该如何稽查?  孙琪峥织梦建站教程如何优化数据库安全?  实现点击下箭头变上箭头来回切换的两种方法【推荐】  杭州银行网站设计制作流程,杭州银行怎么开通认证方式?  如何优化Golang Web性能_Golang HTTP服务器性能提升方法  Android滚轮选择时间控件使用详解  宁波自助建站系统如何快速打造专业企业网站?  建站之星2.7模板快速切换与批量管理功能操作指南  如何快速辨别茅台真假?关键步骤解析  如何在阿里云虚拟服务器快速搭建网站?  婚礼视频制作网站,学习*后期制作的网站有哪些?  东莞专业制作网站的公司,东莞大学生网的网址是什么?  视频网站制作教程,怎么样制作优酷网的小视频?  成都响应式网站开发,dw怎么把手机适应页面变成网页? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。