Migration guide¶
Available on all plans
self-hosted deployments
Migrations help you move your Mattermost deployment or data from one environment to another with minimal disruption. Whether you’re transitioning your Mattermost server to new infrastructure, restructuring your database, or moving from another collaboration platform like Slack, this guide provides step-by-step instructions for each supported path. Use the sections below to quickly find the scenario that matches your needs and follow the recommended process to ensure a smooth migration.
Book a live demo or talk to a Mattermost expert to explore tailored solutions for your organization’s secure collaboration needs. Or try Mattermost yourself with a 1-hour preview for instant access to a live sandbox environment.
Move Mattermost to a new server¶
The following instructions migrate Mattermost from one server to another by backing up and restoring the Mattermost database and config.json
file. For these instructions, SOURCE
refers to the Mattermost server from which your system will be migrated and DESTINATION
refers to the Mattermost server to which your system will be migrated.
Back up your SOURCE Mattermost server. See Backup and Disaster Recovery documentation.
Upgrade your SOURCE Mattermost server to the latest major build version. See Upgrading Mattermost Server documentation.
Install the latest major build of Mattermost server as your
DESTINATION
.
Make sure your new instance is properly configured and tested. The database type (MySQL or PostgreSQL) and version of
SOURCE
andDESTINATION
deployments need to match.Stop the
DESTINATION
server usingsudo stop mattermost
, then back up the database andconfig.json
file.
Migrate database from
SOURCE
toDESTINATION
. Backup the database from theSOURCE
Mattermost server and restore it in place of the database to which theDESTINATION
server is connected.Migrate
config.json
fromSOURCE
toDESTINATION
. Copyconfig.json
file fromSOURCE
deployment toDESTINATION
.If you use local storage (
FileSettings.DriverName
is set tolocal
), migrate./data
fromSOURCE
toDESTINATION
.
Copy the
./data
directory fromSOURCE
deployment toDESTINATION
.If you use a directory other than
./data
, copy that directory instead.
Start the
DESTINATION
deployment by runningsudo start mattermost
. Then go to the System Console, make a minor change, and save it to upgrade yourconfig.json
schema to the latest version using default values for any new settings added.Test that the system is working by going to the URL of an existing team. You may need to refresh your Mattermost browser page in order to get the latest updates from the upgrade.
Once your migration is complete and verified, you can optionally upgrade the Team Edition of Mattermost to Enterprise Edition using the upgrade guide.
Move a GitLab Omnibus instance of Mattermost¶
From Mattermost v11, Mattermost Omnibus has reached end of life. Current Omnibus deployments will continue working as they do today until you decide to migrate. However, after v10.12, you won’t receive security updates or new features through Omnibus. We recommend migrating to one of our supported deployment methods, which will ensure you continue receiving security patches and feature updates.
See the Mattermost Omnibus migration guidance for detailed instructions on migrating your GitLab Omnibus instance of Mattermost.
See the Mattermost Support Knowledge Base article on Migrating Mattermost DB from GitLab Omnibus PostgreSQL installation to a standalone PostgreSQL. This migration is commonly needed when separating Mattermost from GitLab or when moving to dedicated database infrastructure.
Move from Slack¶
See the Migrate from Slack documentation for details on migrating from Slack to Mattermost.
Move from Jabber¶
BrightScout helped a major U.S. Federal Agency rapidly migrate from Jabber to Mattermost and open sourced their Extract, Transform and Load (ETL) tool at https://github.com/Brightscout/mattermost-etl. Read more about their case study online.
Move from Pidgin¶
In some cases, people are using Pidgin clients with different backends to communicate. To continue using Pidgin with a Mattermost backend, consider using Mattermost ETL tool, created by BrightScout, to migrate data from your existing backend into Mattermost.
Then use the Pidgin-Mattermost plugin (complete with an installer for end user machines) to continue to support legacy Pidgin users while offering a whole new Mattermost experience on web, mobile, and PC.
Move from Bitnami¶
Bitnami uses MySQL, and renames the Mattermost database tables by converting the names to all lower case. For example, in non-Bitnami installations, the Users table is named Users
, but in Bitnami, the table is users
(with a lowercase u
). As a result, when you migrate your data from Bitnami to a non-Bitnami installation, you must modify the MySQL startup script so that it starts MySQL in lowercase table mode.
You can modify the script by adding the --lower-case-table-names=1
switch to the MySQL start command. The location of the start-up script generally depends on how you installed MySQL, whether by using the package manager for the operating system, or by manually installing MySQL. You must modify the start-up script before migrating the data.
For more information about letter case in MySQL table names and the --lower-case-table-names
switch, see the Identifier Case Sensitivity topic in the MySQL documentation.
Move from bespoke messaging solutions¶
Mattermost is often selected to replace bespoke solutions by IT and DevOps teams as a stable, enterprise-grade, commercially-supported solution on an open source platform that meets and exceeds the flexibility and innovation of bespoke solutions.
Migrating from bespoke messengers to Mattermost can be challenging. Because of the difficulty of upgrading and maintaining bespoke solutions, the format for storing data is unpredictable, and the community around any single legacy release is small.
If your data in the bespoke messenger is vital, consider:
Mattermost bulk load tool: Use the Mattermost bulk load tool to ETL from your bespoke system to Mattermost.
Mattermost ETL framework from BrightScout: Consider the Mattermost ETL framework from BrightScout to custom-configure an adapter to plug in to the Bulk Load tool mentioned above.
Legacy Slack import: If you only recently switched from Slack to a bespoke tool, consider going back to import the data and users from the old Slack instance directly into Mattermost, leveraging the extensive support for Slack-import provided.
Export to Slack, then import to Mattermost: Export Flowdock, Campfire, Chatwork, Hall, or CSV files to Slack and then export to a Slack export file and import the file into Mattermost.
If your data in the bespoke messenger is not vital, consider:
Parallel systems: Running Mattermost in parallel with your bespoke system until the majority of workflow and collaboration has moved to Mattermost
Hard switch: Announce a “hard switch” to Mattermost after a period of time of running both systems in parallel. Often this has been done due to security concerns in bespoke products or products nearing end-of-life.