Install and configure Docker CE: https://docs.docker.com/desktop/install/mac-install/.
Note: MM-7971 introduced using docker-compose to manage containers. To preserve your data on upgrade, execute the following steps.
First, backup from any existing containers:
mysqldump -h 127.0.0.1 --column-statistics=0 -u mmuser -p mattermost_test > mm_mysql_backup.sql
pg_dump -U mmuser -W -d mattermost_test -h 127.0.0.1 > mm_postgres_backup.bak
Then after upgrading and starting the new docker-compose managed containers, restore the data:
mysql -u mmuser -p -h 127.0.0.1 mattermost_test < mm_mysql_backup.sql
psql -U mmuser -W -h 127.0.0.1 -f mm_postgres_backup.bak mattermost_test
If you don’t migrate your data, the new, docker-compose-managed containers will start out empty. To remove the old containers – destroying any existing data – use make clean-old-docker
.
Download and install homebrew: https://brew.sh/.
Install Go:
brew install go
Update your shell’s initialization script (e.g. .bashrc
or .zshrc
) and add the following:
ulimit -n 8096
Clone the Mattermost source code from your fork:
git clone https://github.com/YOUR_GITHUB_USERNAME/mattermost-server.git
Start the server:
cd mattermost-server
make run-server
Note: If you see lot of nc: bad address 'elasticsearch'
messages, eventually exiting with the message Service elasticsearch:9200 did not start within 300 seconds. Aborting...
, increase the memory available for the Docker Engine by going to Docker's preferences -> Advanced.
Note: If you see an error which says Failed to ping DB
, it’s probably due to a conflict between the PostgreSQL service in Docker and the one which is running system-wide. You can stop the system-wide server temporarily by running brew services stop postgres
in your terminal, then restart the Docker service.
Test your environment:
curl http://localhost:8065/api/v4/system/ping
make stop-server
If successful, the curl
step will return a JSON object:
{"AndroidLatestVersion":"","AndroidMinVersion":"","DesktopLatestVersion":"","DesktopMinVersion":"","IosLatestVersion":"","IosMinVersion":"","status":"OK"}
Note: Browsing directly to http://localhost:8065/ will display a 404 Not Found
until the web app is configured. See Web App Developer Setup and Mobile App Developer Setup for additional setup.
The stop-server
make target does not stop all the docker containers started by run-server
. To stop the running docker containers:
make stop-docker