How to Resize MySQL Database Clusters
Validated on 5 May 2026 • Last edited on 5 May 2026
MySQL is an open source, object-relational database built with speed and reliability in mind. Its large and active developer community has created many third-party applications, tools, and libraries that expand MySQL’s functionality.
You can resize existing MySQL database clusters at any time to change CPUs, RAM, and storage, including scaling up or down when disk utilization and plan limits allow.
Scaling Down
You can scale down compute and storage when the target configuration keeps projected disk utilization at or under 80%. Projected utilization is calculated using the size of your most recent backup plus your current log size. The combined size must be within 80% of the target storage.
Each compute plan enforces minimum and maximum storage values. When scaling down, the target storage must remain within these limits, even if the 80% utilization check would otherwise allow a smaller size. You can choose a smaller compute tier only if the requested storage falls within that tier’s allowed range.
For example, starting from a General Purpose Dedicated CPU plan with 4 vCPU / 16 GiB RAM, 100 GiB storage, and 80 GiB used for data:
| Target configuration | Result |
|---|---|
| Same plan with 90 GiB storage | Allowed (meets 80% limit) |
| General Purpose Dedicated CPU, 2 vCPU / 8 GiB RAM, 90 GiB storage | Allowed (within plan limits) |
| Basic Shared CPU, 1 vCPU / 2 GiB RAM, 90 GiB storage | Not allowed (plan supports maximum storage of 60 GiB) |
| General Purpose Dedicated CPU, 8 vCPU / 32 GiB RAM, 90 GiB storage | Not allowed (plan requires minimum storage of 160 GiB) |
Resize a Database Cluster Using the CLI
To resize a database cluster using doctl, you need to provide a value for the --size flag, which specifies the cluster’s new configuration (number of CPUs, amount of RAM, and hard disk space). Use the doctl databases options slugs command to get a list of available values.
Resize a Database Cluster Using the API
To resize a database cluster using the API, you need to provide a value for the size field, which specifies the cluster’s configuration (number of CPUs, amount of RAM, and hard disk space). Use the /v2/databases/options endpoint to get a list of available values.
Resize a Database Cluster Using the Control Panel
To resize a MySQL database cluster, click the name of the cluster in the control panel to go to its Overview page, then click the Settings tab.
In the Cluster configuration section, click Edit. Select your cluster configuration and CPU option.
Then, select your storage size.
The Autoscale storage section lets you check a box to automatically increase storage when disk utilization on any node in the cluster reaches the specified threshold. The threshold is based on the worst-performing node in the cluster, not the average across nodes. Click Customize to set a custom threshold and storage increment. The system bills this increase as additional storage.
Autoscaling takes several minutes, depending on the cluster size. It runs without downtime, and you do not need to take any action.
Once you have selected your new configuration and size, click Save to provision the new configuration. The provisioning takes several minutes but the total time depends on the size of the cluster.
Your cluster’s state changes from Active to Resizing until the process is done. You can expect no downtime and do not need to take action.