Menu

This is documentation for the next version of Mimir. For the latest stable release, go to the latest version.

Open source

Grafana Mimir deployment modes

You can deploy Grafana Mimir in one of two modes:

  • Monolithic mode
  • Microservices mode

The deployment mode is determined by the -target parameter, which you can set via CLI flag or YAML configuration.

Monolithic mode

The monolithic mode runs all required components in a single process and is the default mode of operation, which you can set by specifying -target=all. Monolithic mode is the simplest way to deploy Grafana Mimir and is useful if you want to get started quickly or want to work with Grafana Mimir in a development environment. To see the list of components that run when -target is set to all, run Grafana Mimir with the -modules flag:

bash
./mimir -modules

Mimir’s monolithic mode

Monolithic mode can be horizontally scaled out by deploying multiple Grafana Mimir binaries with -target=all. This approach provides high-availability and increased scale without the configuration complexity of the full microservices deployment.

Mimir’s horizontally scaled monolithic mode

Microservices mode

In microservices mode, components are deployed in distinct processes. Scaling is per component, which allows for greater flexibility in scaling and more granular failure domains. Microservices mode is the preferred method for a production deployment, but it is also the most complex.

In microservices mode, each Grafana Mimir process is invoked with its -target parameter set to a specific Grafana Mimir component (for example, -target=ingester or -target=distributor). To get a working Grafana Mimir instance, you must deploy every required component. For more information about each of the Grafana Mimir components, refer to Architecture.

If you are interested in deploying Grafana Mimir in microservices mode, we recommend that you use Kubernetes and the mimir-distributed Helm chart.

Mimir’s microservices mode

Read-Write mode

Warning

Read-Write deployment mode is experimental.

The read-write mode provides an alternative to monolithic and microservices modes.

In read-write mode, components are grouped into three services to ease the operational overhead whilst still allowing scale to be tuned separately on the read and write paths. The services group the components as follows:

  • read
    • query-frontend
    • querier
  • backend
    • store-gateway
    • compactor
    • ruler
    • alertmanager
    • query-scheduler
    • overrides-exporter
  • write
    • distributor
    • ingester

Similar to the other modes, each Grafana Mimir process is invoked with its -target parameter set to the specific service: -target=read, -target=write, or -target=backend.

Mimir’s read-write deployment mode

Read-write mode is only available in Jsonnet.