登录
首页 >  Golang >  Go问答

同一时刻同时有10000个请求golang写的http服务

来源:Golang技术栈

时间:2023-04-27 11:27:43 262浏览 收藏

Golang小白一枚,正在不断学习积累知识,现将学习到的知识记录一下,也是将我的所得分享给大家!而今天这篇文章《同一时刻同时有10000个请求golang写的http服务》带大家来了解一下##content_title##,希望对大家的知识积累有所帮助,从而弥补自己的不足,助力实战开发!


问题内容

老师,我现在有个代驾项目,会涉及到高并发,有个问题没能理解透彻,就是比如: 同一时刻同时有10000个请求进入到golang写到http服务(而我如果在执行业务的代码并没有使用goroutine),那么golang是是怎么处理这10000个请求的?

正确答案

这个不用担心,也不用自己开协程来处理请求,大多数http框架都会内部开协程来封装处理这些请求,下面以gin为例:

当有10000个请求进入到Gin的HTTP服务时,Gin会将每个请求都封装成一个HTTP请求对象,并为每个请求创建一个HTTP上下文对象。这些HTTP上下文对象是并发安全的,因此Gin可以同时处理多个请求。

Gin会将每个请求分配给一个goroutine来处理。Goroutine是一种轻量级线程,它可以在一个线程中并发地执行多个任务,因此Gin可以同时处理多个请求。Gin会使用默认的goroutine池来管理这些goroutine,并确保它们能够在需要时进行重用,从而减少了线程切换和goroutine创建的开销。

当请求处理完成时,Gin会将HTTP响应对象返回给客户端。如果你的业务代码中没有使用goroutine,那么Gin会在处理每个请求时使用当前的goroutine,而不是创建新的goroutine。这样可以避免创建大量的goroutine,从而减少系统开销,并提高系统的性能。

今天带大家了解了golang、高并发的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

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