Version 12.0.0
All Classes Functions Variables Typedefs Enumerations Enumerator Modules Pages
Upgrading and downgrading databases

The upgrade/downgrade process is only necessary for major or minor WiredTiger releases (releases where the major or minor version number changed). Patch releases (where only the patch number changed), do not contain any API or file format changes, and do not require anything other than a link step or shared library installation for upgrading or downgrading. However, the complete WiredTiger library must be re-built from scratch when changing versions, as there is no guarantee modules from one version of the library will work with modules from any other version.

The rest of this page discusses upgrading and downgrading WiredTiger major and minor releases. Specifically, by upgrading, we mean migrating an application and its databases to a newer WiredTiger release, and by downgrading, we mean reverting to an older version.

When upgrading or downgrading between WiredTiger releases, there are two components to consider: the WiredTiger library API and the underlying data files used for the database (for example, log files or B+tree files).

As part of each WiredTiger release, a new Upgrading WiredTiger applications documentation section is created, describing changes in the WiredTiger API and in the format of underlying files, if any. Changes to the format of the underlying data files are extremely rare, while changes to WiredTiger API are more common. Generally, when the WiredTiger API changes, the changes are backward compatible and applications do not require modifications in order to upgrade to the new release.

Note it is not necessary to upgrade (downgrade) to intermediate releases, you can ignore intermediate releases and upgrade (downgrade) directly to the release you plan to use.

To upgrade to a new release of WiredTiger:

  1. Review the information for each release after the WiredTiger release you're currently using, up to and including the release you plan to use. Changes to the WiredTiger API are normally backward compatible, that is, you can continue to use the same WiredTiger configuration values used previously. However, it will likely enhance program maintainability to switch to newer versions of the configuration strings, as documentation for the deprecated values will no longer be available.

  2. Once you have reviewed the relevant release notes and modified your application as necessary, install the new version of the application by relinking or installing a new version of the WiredTiger shared library.

  3. Shut down the old version of the application.

  4. Start the new version of the application.

Applications wanting the ability to downgrade to previous releases of WiredTiger are constrained in some important ways:

  • The underlying table file formats must not have changed between the release currently being run and the release to which you are downgrading. In other words, table file format changes are not backward compatible, and an upgraded table file cannot be downgraded without being dumped and re-loaded.
  • If the underlying log file format changed and you have logging enabled in the database, in order to retain the ability to downgrade to earlier releases you must use compatibility option in the call to wiredtiger_open or WT_CONNECTION::reconfigure. When running at an earlier compatibility release setting, the log files generated will be compatible with earlier binaries.

  • Applications concerned with downgrading should configure the wiredtiger_open config_base value to false, so WiredTiger does not write the base configuration file when creating databases. Because the base configuration file is written using a current version of the WiredTiger API, writing this file could cause applications using previous versions of the WiredTiger API to fail. See WiredTiger.basecfg file for more information.

To downgrade to a previous release of WiredTiger:

  1. Shut down the new version of the application.

  2. Start the old version of the application.