登录
首页 >  Golang >  Go问答

golang中goroutine的优先级

来源:stackoverflow

时间:2024-04-16 10:09:35 490浏览 收藏

哈喽!今天心血来潮给大家带来了《golang中goroutine的优先级》,想必大家应该对Golang都不陌生吧,那么阅读本文就都不会很困难,以下内容主要涉及到,若是你正在学习Golang,千万别错过这篇文章~希望能帮助到你!

问题内容

我正在用 golang 编写一个低延迟网络、高吞吐量服务器。它在主 goroutine 中有接受器(接受传入连接)。它将传入连接传递给“n”个工作协程。

在这种情况下,为了不删除连接,我希望接受器 Goroutine 的优先级高于其他 Goroutine,这样连接就不会被删除。或者至少这个接受器 goroutine 不应该被其他工作 goroutine 驱逐。

我怎样才能确保这一点?


解决方案


我在 golang 上创建了线程池。这应该允许人们轻松地优先考虑某些 goroutine 而不是其他 goroutine。

https://github.com/vijayviji/executor

如果您优先考虑接受连接而不是“完成工作”,请考虑随着时间的推移会发生什么。你会积压工作,同时接受越来越多的联系,带来更多的工作要做。这只会增加服务器的负载。

相反,应专注于编写非常高效的工作代码,以便快速完成工作,释放资源来处理新连接。

如果您担心服务器无法处理工作负载,则应该考虑对客户端进行速率限制。

终于介绍完啦!小伙伴们,这篇关于《golang中goroutine的优先级》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布Golang相关知识,快来关注吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>