Required MongoDB versions can change across different major versions. It is very important that you choose the correct database version when deploying and also to make sure your existing installation is using a supported version. This page outlines how you can keep track of the supported versions.
You can always check the supported version list on our GitHub releases page.
Use the following "template" link to inspect the release notes and supported MongoDB releases.
{% hint style="success" %} https://github.com/RocketChat/Rocket.Chat/releases/\ {% endhint %}
For example, if you want to check what are the supported MongoDB versions for release 6.0.0
, you can go to https://github.com/RocketChat/Rocket.Chat/releases/6.0.0 and look for "Engine versions".
Required Mongo version
The other option is to use our releases API.
{% hint style="info" %} This is a relatively new addition; information on old versions can't be viewed by this API. {% endhint %}
This is a very quick way of getting the list and is also ideal if you want to get this information dynamically for some kind of automation or script.
If you want to see the supported MongoDB versions for the latest release, you can perform a GET request against the following endpoint:
https://releases.rocket.chat/latest/info
You can change latest
with any version number and get more specific information. The key you're looking for is compatibleMongoVersions
.
Using curl
with jq
would look something like:
{
"tag": "6.0.0",
"commit": "aa8f0ec70b2267af55d9ce9a3e3abfe7ff6c0a37",
"key": "build/rocket.chat-6.0.0.tgz",
"etag": "8cfdb5bc71da00605faa00c46ef7d929-32",
"count": 2840,
"nodeVersion": "14.21.2",
"compatibleMongoVersions": [
"4.4",
"5.0",
"6.0"
]
}
If it is an existing deployment, being fairly in the middle of the supported list is a good idea. We know how hard it is to update our databases, especially if it's a large deployment.
If you're going to deploy fresh, we recommend choosing the latest version that is supported.
{% hint style="info" %} We don't remove MongoDB support overnight. A version marked to be removed from support is first deprecated and as a workspace admin, you see a deprecation warning in your Rocket.Chat logs and the notice banner on their instances. {% endhint %}
{% hint style="info" %} See a list of Releases, Mongo versions, and their deprecation notice here #mongodb-versions {% endhint %}
Note that without the MongoDB version, we can't ensure you are running a compatible version. If you are running your MongoDB with authentication enabled and a user different from admin, you may need to grant permissions for this user to check cluster data. You can do it via Mongo shell by running the following command replacing the string YOUR_USER with the correct user name:
{% code overflow="wrap" %}
db.runCommand({ grantRolesToUser: "YOUR_USER" , roles: [{role: "clusterMonitor", db: "admin"}]})
{% endcode %}
Mmapv1 is no longer supported in MongoDB since version 4.2. So to make sure you update your Rocket.Chat installations easily in the future, use the WiredTiger storage engine. If you're already running mmapv1, migrate to WiredTiger immediately.