http implementation fasthttp in golang
In some early morning github trending browsing I stumbled across a web framework called Iris, which looks to be really fast, faster in fact that the stdlib, which seemed strange to me. After some browsing of the source code I noticed that Iris is actually using the fasthttp library instead of the net/http standard library for serving http.
It is always a bold claim to say you have created a package that is better, faster and stronger that the implementation of in the standard library. I would know from vestigo url routing.
Looking into fasthttp
After reviewing how handlers are served from fasthttp, I completely have fallen for this library. The creator has done it right. I have mentioned to colleagues how I felt the implementation of the stdlib for net/http has been pretty much completely due to how they run handlers. Looking at the stdlib implementation below it is pretty clear that this implementation uses a separate goroutine PER http request.
Conversely in fasthttp’s implementation there is a workerpool model as the implementation, seen below:
So what?
Well, this is a much better implementation for several reasons:
- 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. - 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
- 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
- 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.
I really hope that the golang net/http maintainers keep this model in mind for golang version 2.