Custom Postgres Config
Supabase projects come with a Postgres cluster that is pre-configured for optimal performance. The configuration is based on a diverse range of workloads as well as the compute add-ons being used in the project. You can override this configuration to better optimize the Postgres cluster for specific workloads.
Custom Postgres Config gives you advanced control over your database. Using it to set values that are inappropriate for your workload or compute add-on could cause severe performance degradation or project instability.
Custom Postgres config
While most Postgres parameters can be configured from within SQL, some parameters must either be set using a config file, or require superuser access. Custom Postgres Config allows you to configure such parameters.
From the perspective of Postgres, config overrides will show up in the global configuration file. Role or database specific configuration could override them for some scenarios; please refer to the Postgres docs on each parameter for additional details.
Supported parameters
The following parameters are available for overrides:
- effective_cache_size
- maintenance_work_mem
- max_connections
- max_locks_per_transaction
- max_parallel_maintenance_workers
- max_parallel_workers_per_gather
- max_parallel_workers
- max_worker_processes
- session_replication_role
- shared_buffers
- statement_timeout
- work_mem
Setting config using the CLI
To get started:
The postgres config
command of the CLI can be used for setting configuration parameters:
_10$ supabase --experimental --project-ref <project-ref> postgres-config update --config max_parallel_workers=6 --config shared_buffers=250MB_10- Custom Postgres Config -_10Config |Value |_10shared_buffers |250MB |_10max_parallel_workers |6 |_10- End of Custom Postgres Config -
By default, the CLI will merge any provided config overrides with any existing ones. The --replace-existing-overrides
flag can be used to instead force all existing overrides to be replaced with the ones being provided:
_10$ supabase --experimental --project-ref <project-ref> postgres-config update --config max_parallel_workers=3 --replace-existing-overrides_10_10- Custom Postgres Config -_10Config |Value |_10max_parallel_workers |3 |_10- End of Custom Postgres Config -
When configuring parameters that require time units, such as statement_timeout
, the CLI expects a string value with a time unit. Supported units include ms
, s
, and min
.
_10$ supabase --experimental --project-ref <project-ref> postgres-config update --config statement_timeout=1000ms_10_10- Custom Postgres Config -_10Config |Value |_10statement_timeout |1000ms |_10- End of Custom Postgres Config -
Considerations
- The Postgres cluster will be restarted in order to change the configuration being used. This will cause momentary disruption to existing database connections; in most cases this should not take more than a few seconds.
- Custom Postgres Config will always override the default optimizations generated by Supabase. When changing compute add-ons, you should also review and update your custom Postgres Config to ensure they remain compatible and effective with the updated compute.
Pooler config
You can also customize some parameters for the Connection Pooler:
The default pool size, and the maximum number of clients allowed to connect concurrently is automatically optimized based on the compute add-on being used. At the moment, the Dashboard only reflects any custom configuration being used, and does not include the default optimized numbers used for your project.
Custom Pooler Config may also require manual updates to any relevant overrides when changing compute add-ons.