golang php 高并发,golang如何实现高并发? - Go语言中文社区

golang php 高并发,golang如何实现高并发?


golang实现高并发的方法:首先M关联了一个内核线程,并通过调度器P的调度,接1个或者多个G;然后由M和P的一对一关系,通过P调度N个G;最后实现内核线程和G的多对多关系【M:N】。

dc54416ce21162f72fae65f6a70fefea.png

golang实现高并发的方法:

go语言使用MPG模式来实现CSP

在传统的并发中起很多线程只会加大CPU和内存的开销,太多的线程会大量的消耗计算机硬件资源,造成并发量的瓶颈。M指的是Machine,一个M直接关联了一个内核线程。

P指的是”processor”,代表了M所需的上下文环境,也是处理用户级代码逻辑的处理器。

G指的是Goroutine,其实本质上也是一种轻量级的线程。

561a475406a888038e934dd62c0098eb.png

我个人的理解:M关联了一个内核线程,通过调度器P(上下文)的调度,可以连接1个或者多个G,相当于把一个内核线程切分成了了N个用户线程,M和P是一对一关系(但是实际调度中关系多变),通过P调度N个G(P和G是一对多关系),实现内核线程和G的多对多关系(M:N),通过这个方式,一个内核线程就可以起N个Goroutine,同样硬件配置的机器可用的用户线程就成几何级增长,并发性大幅提高。相关学习推荐:Go语言教程

版权声明:本文来源CSDN,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/weixin_39746382/article/details/115239606
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。
  • 发表于 2021-05-17 22:59:06
  • 阅读 ( 1279 )
  • 分类:Go

0 条评论

请先 登录 后评论

官方社群

GO教程

猜你喜欢