# Update to the latest Meilisearch version

Currently, Meilisearch databases can only be opened by the Meilisearch version you used to create them. The following guide will walk you through all the steps to migrate an existing database from an older version of Meilisearch to the most recent one.

If you already have a Meilisearch database with some data you don’t want to lose, you are in the right place!

NOTE

If you have already installed the latest version and manually indexed your data and settings, you can ignore this guide.

# Verify your database version

Before we begin, you need to verify the version of Meilisearch that's compatible with your database, i.e., the version that indexed the data. You can do so by launching a Meilisearch instance:

./meilisearch --master-key="MASTER_KEY"

If Meilisearch launches successfully, use the get version endpoint, note your pkgVersion, and proceed to the next step.

curl \
  -X GET 'http://localhost:7700/version' \
  -H 'Authorization: Bearer API_KEY'

NOTE

If you're using v0.24 or below, use the X-MEILI-API-KEY: apiKey authorization header:

curl \
  -X GET 'http://localhost:7700/version' \
  -H 'X-Meili-API-Key: API_KEY'  

The response should look something like this:

{
  "commitSha": "stringOfLettersAndNumbers",
  "commitDate": "YYYY-MM-DDTimestamp",
  "pkgVersion": "x.y.z"
}

If you get the error Cannot open database, expected Meilisearch engine version: 0.X.X, current engine version 0.Y.Y, your database is not compatible with the currently installed Meilisearch version.

In this case, you need to download the compatible version now (i.e., 0.X.X in the above error message) so that you can access and export your database.

NOTE

If you are updating to v0.28, keys imported from the old version will have their key and uid fields regenerated.

# Proceed according to your database version

Now that you know which Meilisearch version your database is compatible with, proceed accordingly:

  • If your database version is v0.15.0 or above, continue to the next section.
  • If your version is v0.14.0 or below, go here.

# Updating from v0.15.0 or above

Because Meilisearch v0.15.0 and above include the dumps feature, updating is relatively simple.

In this guide, we will:

  1. Set all fields as displayed attributes
  2. Create a dump using the Meilisearch version that's compatible with your database
  3. Delete the database folder
  4. Import the dump using the most recent Meilisearch version

# Step 1: Set all fields as displayed attributes

NOTE

If your dump was created in Meilisearch v0.21 or above, continue to step 2.

When creating dumps, Meilisearch calls the same method as the get documents endpoint. This means that all fields must be displayed in order to be saved in the dump.

Start by using the get displayed attributes endpoint to verify that all attributes are displayed.

# whenever you see {index_uid}, replace it with your index's unique id
curl \
  -X GET 'http://localhost:7700/indexes/{index_uid}/settings/displayed-attributes' \
  -H 'Authorization: Bearer API_KEY'

If the response is {'displayedAttributes': '["*"]'}, you can move on to the next step.

If it's something else, then you need to use the reset displayed attributes endpoint. Before doing this, make sure you save your list of displayed attributes somewhere so you can restore it afterwards.

curl \
  -X DELETE 'http://localhost:7700/indexes/{index_uid}/settings/displayed-attributes' \
  -H 'Authorization: Bearer API_KEY'

This command returns a taskUid. You can use this to track the status of the operation. Once the status is succeeded, you're good to go.

Now that all fields are displayed, proceed to the next step.

# Step 2: Create the dump

Before creating your dump, make sure that your dump directory is somewhere accessible. By default, dumps are created in a folder called dumps at the root of your Meilisearch directory.

NOTE

If you are running Meilisearch in a service using systemd, like AWS or a DO droplet, the dumps folder can be found in the configuration file directory, cd /var/opt/meilisearch/dumps.

If you're unsure where your Meilisearch directory is located, try this:

To create a dump, use the create dump endpoint.

curl \
  -X POST 'http://localhost:7700/dumps' \
  -H 'Authorization: Bearer API_KEY'

The server should return a response that looks like this:

{
  "taskUid": 1,
  "indexUid": null,
  "status": "enqueued",
  "type": "dumpCreation",
  "enqueuedAt": "2022-06-21T16:10:29.217688Z"
}

This command returns a taskUid. You can use this to track the status of your dump. Keep in mind that the process can take some time to complete.

Once the dumpCreation task shows "status": "succeeded", you're ready to move on.

{
  "uid": 1,
  "indexUid": null,
  "status": "succeeded",
  "type": "dumpCreation",
  "details": {
    "dumpUid": "20220621-161029217"
  },
  "duration": "PT0.025872S",
  "enqueuedAt": "2022-06-21T16:10:29.217688Z",
  "startedAt": "2022-06-21T16:10:29.218297Z",
  "finishedAt": "2022-06-21T16:10:29.244169Z"
}

# Step 3: Delete the database folder

To delete the old Meilisearch version, you need to delete the data.ms folder. data.ms should be at the root of the Meilisearch binary, unless you chose another location.

TIP

If you are using the Meilisearch official images on DigitalOcean, AWS, or GCP, you will find the data.ms folder at /var/lib/meilisearch/data.ms.

# Step 4: Import the dump

Now that you’ve got your dump, install the latest version of Meilisearch and import the dump at launch using the CLI option.

# launch the latest version of Meilisearch with the master key and import the specified dump file
./meilisearch --import-dump /dumps/your_dump_file.dump --master-key="MASTER_KEY"

WARNING

If you are using Meilisearch v0.20 or below, migration should be done in two steps. First, import your dump into an instance running any version of Meilisearch from v0.21 to v0.24, inclusive. Second, export another dump from this instance and import it to a final instance running your targeted version.

Importing a dump requires indexing all the documents it contains. Depending on the size of your dataset, this process can take a long time and cause a spike in memory usage.

Finally, don’t forget to set displayedAttributes back to its previous value if necessary. You can do this using the update displayed attributes endpoint.

Congratulations! You have successfully migrated your Meilisearch database to the latest version! πŸŽ‰

# Updating from v0.14.0 or below

Since these versions predate the dumps feature, the best solution is to export your documents and your index settings as .JSON files.

In this guide, we will:

  1. Save your settings
  2. Set all fields as displayed attributes
  3. Save your documents
  4. Delete the database folder
  5. Upload your data to the latest version of Meilisearch

If you don’t need to preserve index settings, skip directly to step two.

# Step 1: Save your settings

First, use the get settings endpoint to retrieve the settings of any indexes you want to preserve, and save them to a file using the method you prefer.

No example found

Repeat this process for all indexes you wish to migrate.

It is important to save your settings before exporting documents, since the next step may require you to modify the settings.

# Step 2: Set all fields as displayed attributes

To prevent data loss, all fields must be set as displayed.

By default, all fields are added to the displayed attributes list. Still, it's a good idea to verify this before proceeding to the next step. You can do so by using the get displayed attributes endpoint:

No example found

If the response is '["*"]', you can move on to the next step.

If it's something else, then you need to use the reset displayed-attributes endpoint. Before doing this, make sure you save your list of displayed attributes somewhere so you can restore it afterwards.

No example found

This command should return a summarized task object with type as indexUpdate.

Now that all fields are displayed, proceed to the next step.

# Step 3: Save your documents

Use the get documents endpoint to retrieve your documents and save them using the method you prefer. Make sure to set the limit on documents returned so that, if you have some number of documents n, limit β‰₯ n. Otherwise, you risk data loss.

No example found

# Step 4: Delete the database folder

To delete the old Meilisearch version, you need to delete the data.ms folder. data.ms should be at the root of the Meilisearch binary, unless you chose another location.

# Step 5: Upload your data to the latest version of Meilisearch

Finally, install the latest version of Meilisearch and upload your data as usual.

If you chose to save your settings, make sure to follow this order:

No example found
No example found

Since updating the settings requires re-indexing all documents, this order saves time and memory.

Congratulations! You have successfully migrated your Meilisearch database to the latest version! πŸŽ‰