Deploy requests
Overview
Deploy requests are an integral part of the PlanetScale workflow. Database branching, coupled with deploy requests, allows you to deploy non-blocking schema changes to your production database with zero downtime. You can also undo deployments without losing any data that was written during that time.
Create a deploy request
Note
Your database must have a branch with safe migrations enabled before you can create a deploy request.
- Click on "Branches".
- Select the development branch you want to deploy to the base branch.
- This page shows you a diff of the schema against its base branch.
- To the right of the page, you'll see a dropdown that says "Deploy to".
- Select the branch you want to deploy to.
- Optionally, add a comment about the deploy request.
- Click "Create deploy request".
Review a deploy request
Once you create a deploy request, you or your team can review it and, optionally, approve it before deploying it.
PlanetScale will check if the request is deployable. This process includes checking for issues like:
- Incompatible unique keys
- Invalid charsets (PlanetScale supports
utf8
,utf8mb4
,utf8mb3
,latin1
, andascii
) - Invalid foreign key constraint names or lengths
- And other various checks to ensure successful schema changes
We will also warn you about potential data loss or inconsistencies and check if there are any known conflicts with the production schema that could prevent a clean merge. While we attempt to find all possible conflicts, it is ultimately up to you to confirm merge details.
- Click the "Deploy requests" tab on the database dashboard page.
- Select the open deploy request you want to review.
- Under "Summary", you'll see if the request is deployable.
- To review the schema changes, click the "Schema changes" tab.
- You'll see the proposed changes here. New additions are highlighted in green, and deletions are highlighted in red.
- If you have required deploy requests to be approved before deployment, other users in your Organization will see the option to "Approve changes" or "Leave a comment" on the "Schema changes" tab.
Note: If you are the only administrator in your Organization and you enable the "Require administrator approval for deploy requests" setting, you can self-approve your own deploy requests. If there is more than one administrator, self-approval is not allowed.
Reviewing changes across shards
If your deploy request contains changes to a sharded keyspace, you can see the affected shards by clicking the arrow next to each changed table. This will show the SQL that will run, and in the next tab, each shard that will be affected.
Deploy a deploy request
Once the request is approved, if required, it's ready to be added to the deploy queue. Click on the "Summary" tab, and you'll see the option to deploy.
Here you'll have the option to choose to "Deploy changes" or to "Deploy changes instantly":
Deploy changes
- You also have the option to enable gated deployments, which gives you the power to control exactly when the migration cuts over. You'll see an "Auto-apply changes" checkbox, which is checked by default. If you uncheck this, you will get the option to apply the changes once the schema changes are complete. If you leave it checked, it will auto-deploy as soon as it's ready.
- When you're ready to deploy, click "Deploy changes". The deployment will begin or be queued if there are other pending deployments.
- You also have a chance to enable gated deployments in this step.
- You also have the option to run the migration using MySQL's ALGORITHM=INSTANT. If you would like to deploy instantly, see the Deploy changes instantly section below.
- If you enabled gated deployments (step 3), you can click "Apply changes" to merge the deployment to production once it completes.
- After you deploy, you have 30 minutes to "undo" it using our schema revert feature.
- If you are deploying changes to a sharded keyspace, you'll see the progress for each shard here as well.
Deploy changes instantly
You also have the option to use MySQL'S ALGORITHM=INSTANT to instantly deploy the schema change. Learn more in the Instant Deployments section.
- When you're ready to deploy, click "Deploy changes instantly". The deployment will begin or be queued if there are other pending deployments.
- Though the deployment many be queued, once it's at the front of the queue, it will be deployed instantly.
- Instant deployments cannot be reverted.
If you would like to require an administrator's approval before a request can be deployed, go to the "Settings" page for your database and check the "Require administrator approval for deploy requests" box. You must be an Organization Administrator to enable this restriction. Please note you will not be able to approve your own deploy requests.
Close a deploy request
If you decide you don't want to proceed with a deploy request, you can easily close it.
- Click the "Deploy requests" tab on the database dashboard page.
- Select the request you want to close.
- Click on the "Close deploy request" button on the right-hand side.
Deploy requests and foreign key constraints
In most cases, deploy requests should work as expected when your schema changes have foreign key constraints.
There are some cases where a deploy request will not be deployable. This includes cases where there is a mismatched column type or when a foreign key constraint references a deleted column.
For example, if we open a deploy request to add a foreign key constraint t1_id
with type BIGINT
on a table t2
that references a column id
on table t1
, where t1.id
's type is BIGINT
, the following cases would produce a linting error in the deploy request because it is not deployable:
- if, while the previously mentioned deploy request is open, someone else updates
t1.id
to a different column type, i.e.,int
. - if, while the previously mentioned deploy request is open, someone else deletes
t1.id
. - if, while the previously mentioned deploy request is open, someone else deletes all indexes that cover
t1.id
as their prefix. (Because in a foreign key relationship, the referenced columns on the parent table must be indexed, usually by a dedicated index, but they can be the first columns in an otherwise wider index.)
These are all cases where another user changes schema, causing the initial user's definition to be invalid MySQL.
There are also two cases where a revert would cause orphaned rows that you can read about in this document's revert section.
Validating referential integrity of existing columns
Deploy requests do not validate the referential integrity of existing columns. ALTER TABLE… ADD FOREIGN KEY…
does not validate existing row relations within the context of a deploy request. Unlike standard MySQL, it is possible to add the foreign key constraint to a table with orphaned rows, and they will remain orphaned. In standard MySQL, adding a foreign key is a blocking operation, and it fails if any orphaned rows are found.
Instant deployments
Instant deployments give you the option to run schema changes using MySQL's ALGORITHM=INSTANT. This is different than how our online schema migrations work.
Instant deployments will apply schema changes faster, however, these schema changes must be auto-applied and cannot be reverted.
Who should use instant deployments?
We recommend instant deployments to experienced users that are making schema changes to large tables, or users that would like their schema changes to be deployed instantly.
Supported operations
In order for a deploy request to be instantly deployed, all schema changes in the deploy request must be instantly deployable. Some of those changes include:
- Adding or dropping a column (with some exceptions)
- Changing or dropping a column's default value
- Changing an
ENUM
orSET
definition
The following changes are examples of changes that are not instantly deployable:
- Changing a column's data type
- Adding a column with a non-literal default value
- Adding or dropping an index
- Adding or dropping a foreign key constraint
- Extending a
VARCHAR
column size - Updating a column to
NULL
orNOT NULL
To know whether or not a deploy request is instantly deployable, look for the "Instantly deployable" badge on your deploy request. This badge will only be visible on deploy requests that can be deployed instantly.
We recommend reading MySQL's Online DDL documentation for the full list of operations that can be deployed instantly.
Note
Instant deployments are not yet available for all databases.
Gated deployments
Gated deployments give you more control over when a migration goes live after the deployment process completes.
As part of our non-blocking schema change process, instead of directly modifying table(s) when you deploy a deploy request, we make a copy of the affected table(s) and apply changes to the copy. We get the data from the original table and the copy table in sync, and once complete, initiate a quick cutover where we swap the tables.
Note
Note: If a deploy request includes changes to multiple tables, all tables cut over at the same time — unless there is a sequential dependency.
With gated deployments, you can initiate the deployment, but once the table syncing is complete, we'll hold off on the cutover and let you click a button to swap the tables and complete the deployment. Gated deployments can be enabled on each deploy request by unchecking the "Auto-apply changes" box before you deploy.
This feature is helpful if you have long-running migrations. For very large or complex databases, deploying a schema change can take several hours to complete. In those scenarios, you don't want the cutover to happen while you're offline. With gated deployments, you can start the deployment process by adding your deploy request to the queue, and once it's done, you'll be able to click a button to merge it in and complete the deployment while you're there to monitor it.
Enable gated deployments
When you open a deploy request, uncheck the "Auto-apply changes" box.
Once your deploy requests begins running, you'll also have the option to uncheck the box here.
When your deploy request has completed and is ready for cutover, the "Apply changes" button will appear. You can now complete the deployment at any time by clicking this button.
Note
If you have an open gated deployment, you cannot deploy another deploy request until the current one has been merged in.
For more information about this process and why we built it, check out the Gated Deployments: Addressing the complexity of schema deployments at scale blog post.
Note
Deploy requests that are instantly deployed cannot be gated.
Temporary tables
When using deploy requests, you may notice some additional tables in your database ending with a _vrepl
suffix. These are temporary tables that VReplication creates while running your online schema changes.
We clean them up automatically and they do not count against the storage limits of your selected plan. If you want to learn more about how we perform online schema changes, please refer to our Online schema change tools article.
Revert a schema change
If you ever merge a deploy request, only to realize you need to undo it, PlanetScale can handle that! You have the option to revert a recently deployed schema change while maintaining data that was written to the original schema during that time.
Note
Deploy requests that are instantly deployed cannot be reverted.
How to revert a schema change
You can revert a deployment for up to 30 minutes after the deploying. After the 30 minute period is up, the deployment becomes permanent, and you will no longer have the option to revert.
- Select the deploy request you want to revert.
- To revert the schema changes made with the deploy request, click "Revert changes" and confirm.
- We will immediately revert the base branch back to its previous schema.
- Any data that was written to the original schema in the time between deploying and reverting will remain in your database after the revert.
- The deploy request will be closed, but the branch will remain for you to continue development on if you choose.
When is data not retained
There are some scenarios where some data is not retained when you revert your changes.
- You add a table or column to your schema and then revert it. If any data was written to those newly introduced fields between deployment and reverting, that data will not be retained upon revert, as the fields will no longer exist.
When a revert can result in orphaned rows
In some cases, when you are using foreign key constraints, a revert of a deploy request can result in orphaned rows. These can happen when your schema change is:
- Dropping a foreign key constraint: Once a foreign key constraint is dropped, new data written to the table is less constrained. Reverting this change may result in data that is inconsistent with the dropped foreign key constraint.
- Dropping a table with foreign key constraints: When a table with foreign key constraints is dropped, the parent table(s) will continue to be written to. If this change is reverted, data in the table that was dropped may no longer be consistent with its foreign key constraints.
Note
You must enable foreign key constraint support in the database settings page before using them.
When are you unable to revert a schema change
There are also some edge cases where reverting a schema change is not possible. We will always attempt to revert, but if there are scenarios where your data integrity is at risk, we will not proceed with the revert. The following are some cases where a revert will fail:
- If you deploy a schema change that expands the length of some column, such as changing from
VARCHAR(10)
toVARCHAR(50)
, and add new data larger than 10 characters to it, a revert attempt may fail. This is to protect your data. You may have written data to theVARCHAR(50)
field in that time that will not fit in the smaller 10 character space. If no data is added between deployment and revert, the revert process can proceed. - Some examples of other similar scenarios where revert won't be possible (again, only if larger sized data is added between deployment and revert) are:
INT
toBIGINT
NOT NULL
toNULL
TIMESTAMP
toTIMESTAMP(6)
utf8
toutf8mb4
- Any other operation that expands the size of a field
- If you deploy a schema change that removes a unique key or relaxes a unique constraint, and in the time between deployment and attempting to revert, you insert rows that would otherwise conflict with that constraint, the revert may fail.
- Another uncommon but possible scenario: you deploy a schema change that has a
NOT NULL
column without aDEFAULT
value, combined with anALTER TABLE DROP COLUMN
statement for that column. If you insert some rows between the deployment and the revert attempt, the revert will fail. We will not be able to re-add that column for the newly inserted rows and will not know how to populate it.
For an in-depth look at how this process works, check out our Behind the scenes: how schema reverts work blog post.
Schema revert and migration data
If you've selected a migration framework or specified a table with migration data in the settings tab of your database, the data within the table that tracks migrations will be moved to the production branch only after the revert window has been closed. This is to ensure that if the deploy request is reverted, the production branch has the correct log of applied migrations.
Billing considerations
You may see some temporary _vt
tables in your database. These are used to facilitate the deployment and revert process and do not count toward your storage.
Need help?
Get help from the PlanetScale Support team, or join our GitHub discussion board to see how others are using PlanetScale.