老师,我现在有个代驾项目,会涉及到高并发,有个问题没能理解透彻,就是比如: 同一时刻同时有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,从而减少系统开销,并提高系统的性能。