clustering
To improve the performance and reliability of your Brisa application, you can enable clustering through the clustering
configuration property. When clustering
is true
, Brisa will fork the process for each CPU core and will load balance the requests.
The default value is true
in production and when the operating system will load balance the requests correctly. Otherwise, the default value is false
.
The load balancing is working fine only in Linux. On Windows and macOS, the operating system does not load balance HTTP connections as one would expect.
Example
//brisa.config.ts
import type { Configuration } from "brisa";
export default {
clustering: true, // This enable clustering in prod and dev.
} satisfies Configuration;
To make it possible, Brisa uses node:cluster
to handle the clustering. This Node API also works in Bun.
Why should I turn off clustering?
If you are using a popular process manager like PM2, make sense to use clustering: false
in Brisa to avoid conflicts between the process manager and Brisa.
PM2 work by default for Node.js applications, and it will handle the clustering for you. However, you can use PM2 with Bun.js as well.
If you need to use a Custom Server, this configuration does not apply, and you need to handle the clustering yourself.