Managed RDS instances deployed with Qovery have by defualt a maintenance window configured, applying database updates only during the specifyied timeframe (see more information here).
During the maintenance window, a downtime has to be expected on your service since the upgrade might takes a few minutes to take effect.
If this is not acceptable for your business, AWS allows you to deploy changes via the Blue/Green Deployments.
This basically allows you to create a copy of your database with the new configuration (called "Green group") and then switch over to the new database by removing the old instance ("Blue group").
Blue/Green deployments on RDS are not natively supported by Qovery but you can follow this guide to upgrade your RDS instances.
How to configure
To better explain the process, we will try to upgrade an RDS PostgreSQL instance from the version 14 to the version 15.
Activate the logical replication
Logical replication is necessary to use the RDS Blue/Green deployment feature.
To enable the logical replication you have to:
- Create a Custom DB Parameter group. Make sure it targets your current engine type (PostgreSQL) and version (Parameter group family = postgres14), let's call it
parameter-group-14
. (Documentation here) - Edit the DB parameter group
parameter-group-14
and activate the logical replication by settingrds.logical_replication
to1
(Documentation here) - Associate the DB Parameter group
parameter-group-14
to your database. If you have read replicas, associate the parameter group to the replicas as well. (Documentation here) - Reboot your database to apply the changes or wait for the next maintenance window for applying these changes.
Enable logical replication for the "Green" database
We will create a separate DB Parameter group for our "Green group" so that we will ensure that the you won't have to do the previous step the next time.
- Create a Custom DB Parameter group. Make sure it targets your next engine type and version (Parameter group family), let's call it
parameter-group-15
Documentation here) - Edit the DB parameter group
parameter-group-15
and activate the logical replication by settingrds.logical_replication
to1
(Documentation here)
Launch the Blue/Green deployment
Create the Blue/Green Deployment
- Go on the Database list on the AWS console, select the database and press the "Create new Blue/Green Deployment" button.
- Define a name for the deployment (blue-green-upgrade), ensure you select the right engine version (PostgreSQL 15) and the right DB parameter group (parameter-group-15) and create the Blue/Green deployment.
- Wait for all the instances to be
Available
.
AWS Documentation here
Apply the switch over
- From the Database list on the AWS console, select the Blue/Green deployment
blue-green-upgrade
- From the action list, select "Switch over"
- Verify that everything is fine on the configuration and confirm the switch over. This will make the "Green group" the new production environment.
- Wait for the switch over to be completed.
Delete the blue/green deployment
- From the Database list on the AWS console, select the Blue/Green deployment
blue-green-upgrade
- From the action list, select "Delete"
- Once completed, from the Database list on the AWS console, select the database in version 14 (note it should be renamed with a suffix
old
) - From the action list, select "Delete"
- Wait for the delete operation to be completed before moving to the next step
Align the configuration on Qovery
- Go on the Qovery console and align the database configuration by setting the version to
15
- Re-deploy your database.