Step-by-step guide to upgrade to Strapi 5
The latest major version of Strapi is Strapi 5, which is currently provided as a Release Candidate (RC) version, not as a stable version yet.
It is strongly advised not to upgrade a critical or production-ready project from Strapi v4 to Strapi 5.
The content of migration resources might not be final yet. Migration resources are currently only provided to prepare you for the upgrade to Strapi 5 when it is released as a stable version.
Strapi 5 is currently only provided as a Release Candidate (RC) version and is not meant to be used in production yet.
The present page is meant to be used as step-by-step instructions for upgrading your Strapi v4 application to Strapi 5.
Your Strapi v4 application is already running on the latest v4 minor and patch version. If it's not, run the upgrade tool with the minor command to reach it: npx @strapi/upgrade minor.
Step 1: Get ready to upgradeβ
Before getting into the upgrade process itself, take the following precautions:
- Backup your database. - If you are using SQLite (the default database provided with Strapi), your database file is named - data.dband is located in the- .tmp/folder at the root of your Strapi application.- If you are using another type of database, please refer to their official documentation (see PostgreSQL docs and MySQL docs). - If your project is hosted on Strapi Cloud, you can manually create a backup. 
- Backup your code: - If your code is versioned with git, create a new dedicated branch to run the migration.
- If your code is not versioned with git, create a backup of your working Strapi v4 code and store it in a safe place.
 
- Ensure the plugins you are using are compatible with Strapi 5. - To do so, list the plugins you are using, then check compatibility for each of them by reading their dedicated documentation on the Marketplace website. 
Step 2: Run automated migrationsβ
Strapi provides a tool to automate some parts of the upgrade to Strapi 5: the upgrade tool.
- Run the upgrade tool. - npx @strapi/upgrade major- β οΈ Upgrading while Strapi 5 is in RC:- Warning: It is not recommended to migrate a production-level project to Strapi 5 before the release of the stable version. Migrate to Strapi 5 release candidate (RC) at your own risk. - As long as Strapi 5 is available as a RC, the proper command to upgrade is different and depends on the RC version you want to reach. For instance, to reach Strapi 5.0.0-rc.6, the command is: - npx @strapi/upgrade@rc to 5.0.0-rc.6 -c 5.0.0- The command will execute the update and installation of the dependencies of Strapi 5, and run the codemods to handle some of the breaking changes that come with Strapi 5. - The codemods will handle the following changes: - Codemod name and GitHub code link - Description - dependency-remove-strapi-plugin-i18n - Remove the i18n plugin dependency as i18n is now integrated into the core of Strapi - dependency-upgrade-react-router-dom - Upgrade the react-router-dom dependency - dependency-upgrade-styled-components - Upgrade the styled-components dependency - entity-service-document-service - Partly handle the migration from the Entity Service API to the new Document Service API - s3-keys-wrapped-in-credentials - Wrap the - accessKeyIdand- secretAccessKeyproperties inside a- credentialsobject for users using the- aws-s3provider- sqlite3-to-better-sqlite3 - Update the sqlite dependency to better-sqlite3 - strapi-public-interface - Transform - @strapi/strapiimports to use the new public interface- use-uid-for-config-namespace - Replace string dot format for config get/set/has with uid format for 'plugin' and 'api' namespace where possiblenamespace - utils-public-interface - Update utils to use the new public interface 
- Go over the changes made by the upgrade tool to check if you have to manually complete some code updates: - Look for - __TODO__automatically added to your code by the codemods.
Step 3: Check and handle manual upgradesβ
The following main changes might affect your Strapi application and require you to do some manual actions.
For each of them, read the indicated breaking change entry and check if some manual actions are still required after the upgrade tool has run:
- Database migration:- MySQL v5 is not supported π see breaking change
- Only better-sqlite3 is supported π see breaking change
- Only mysql2 is supported π see breaking change
- Lifecycle hooks are triggered differently π see breaking change
 
- Configuration:- Some environment variables are handled by the server configuration π see breaking change
- Custom configuration must meet specific requirements π see breaking change
 
- Admin panel customization:- The helper-plugin has been deprecated π see migration reference
 
π Finally, go over the rest of the breaking changes database for any edge case you might be concerned about.
Step 4: Migrate the API consuming sideβ
Strapi 5 has updated both the REST and GraphQL APIs.
Follow the steps below and leverage retro-compatibility flags and guided migration resources to gradually update your code for Strapi 5.
Migrate REST API callsβ
- Enable the retro-compatibility flag by setting the Strapi-Response-Format: v4header.
- Update your queries & mutations only, guided by the dedicated breaking change entry for REST API.
- Validate that your client is running correctly.
- Disable the retro-compatibiliy flag by removing the Strapi-Response-Format: v4header and start using the new response format.
Migrate GraphQL API callsβ
- Enable the retro-compatibility flag by setting v4ComptabilityModetotruein thegraphl.configobject of the/config/plugins.js|tsfile.
- Update your queries and mutations only, guided by the dedicated breaking change entry for GraphQL.
- Validate that your client is running correctly.
- Disable the retro-compatibily flag by setting v4ComptabilityModetotrueand start using the new response format.