gpt4 book ai didi

go - 为什么 fasthttp 比 net/http 快?

转载 作者:IT老高 更新时间:2023-10-28 13:05:12 33 4
gpt4 key购买 nike

一个 fasthttp基于服务器的速度比 net/http 快 10 倍。

哪些实现细节使 fasthttp 变得如此之快?此外,它如何比 net/http 更好地管理传入请求?

最佳答案

文章“http implementation fasthttp in golang”来自 husobee提及:

Well, this is a much better implementation for several reasons:

  1. The worker pool model is a zero allocation model, as the workers are already initialized and are ready to serve, whereas in the stdlib implementation the go c.serve() has to allocate memory for the goroutine.
  2. The worker pool model is easier to tune, as you can increase/decrease the buffer size of the number of work units you are able to accept, versus the fire and and forget model in the stdlib
  3. The worker pool model allows for handlers to be more connected with the server through channel communications, if the server needs to shutdown for example, it would be able to more easily communicate with the workers than in the stdlib implementation
  4. The handler function definition signature is better, as it takes in only a context which includes both the request and writer needed by the handler. this is HUGELY better than the standard library, as all you get from the stdlib is a request and response writer… The work in go1.7 to include context within the request is pretty much a hack to give people what they really want (context) without breaking anyone.

Overall it is just better to write a server with a worker pool model for serving requests, as opposed to just spawning a “thread” per request, with no way of throttling out of the box.

关于go - 为什么 fasthttp 比 net/http 快?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41627931/

33 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com