By default, Nest makes use of the Express framework. As mentioned earlier, Nest also provides compatibility with other libraries such as, for example, Fastify. Nest achieves this framework independence by implementing a framework adapter whose primary function is to proxy middleware and handlers to appropriate library-specific implementations.
info Hint Note that in order for a framework adapter to be implemented, the target library has to provide similar request/response pipeline processing as found in Express.
Fastify provides a good alternative framework for Nest because it solves design issues in a similar manner to Express. However, fastify is much faster than Express, achieving almost two times better benchmarks results. A fair question is why does Nest use Express as the default HTTP provider? The reason is that Express is widely-used, well-known, and has an enormous set of compatible middleware, which is available to Nest users out-of-the-box.
But since Nest provides framework-independence, you can easily migrate between them. Fastify can be a better choice when you place high value on very fast performance. To utilize Fastify, simply choose the built-in
FastifyAdapter as shown in this chapter.
First, we need to install the required package:
warning Warning When using
apollo-server-fastify, GraphQL playground may not work due to incompatibility with
^3.0.0. You may want to use the unstable
^3.0.0-alpha.3or temporarily choose express instead.
Once the Fastify platform is installed, we can use the
By default, Fastify listens only on the
localhost 127.0.0.1 interface (read more). If you want to accept connections on other hosts, you should specify
'0.0.0.0' in the
Keep in mind that when you use the
FastifyAdapter, Nest uses Fastify as the HTTP provider. This means that each recipe that relies on Express may no longer work. You should, instead, use Fastify equivalent packages.
Fastify handles redirect responses slightly differently than Express. To do a proper redirect with Fastify, return both the status code and the URL, as follows:
You can pass options into the Fastify constructor through the
FastifyAdapter constructor. For example:
A working example is available here.