2017-02-04 07:07:23 +01:00
# Production Docker deployment for Mattermost
2015-11-30 07:09:07 +01:00
2017-02-23 22:32:24 +01:00
This project enables deployment of a Mattermost server in a multi-node production configuration using Docker.
2016-04-12 07:09:03 +02:00
2016-04-24 17:44:04 +02:00
[![Build Status ](https://travis-ci.org/mattermost/mattermost-docker.svg?branch=master )](https://travis-ci.org/mattermost/mattermost-docker)
2017-02-23 22:32:24 +01:00
Notes:
2017-03-13 23:26:45 +01:00
- The default Mattermost edition for this repo has changed from team edition to enterprise edition. Please see [Choose Edition ](#choose-edition-to-install ) section.
2017-06-08 11:13:10 +02:00
- To install this Docker project on AWS Elastic Beanstalk please see [AWS Elastic Beanstalk Guide ](./contrib/aws/README.md ).
2017-06-02 23:56:51 +02:00
- To run Mattermost on Kubernetes you can start with the [manifest examples in the kubernetes folder ](contrib/kubernetes/README.md )
2017-02-04 07:07:23 +01:00
- To install Mattermost without Docker directly onto a Linux-based operating systems, please see [Admin Guide ](https://docs.mattermost.com/guides/administrator.html#installing-mattermost ).
2015-11-30 07:09:07 +01:00
2017-02-23 22:32:24 +01:00
## Installation using Docker Compose
2017-02-04 07:07:23 +01:00
2017-02-23 22:32:24 +01:00
The following instructions deploy Mattermost in a production configuration using multi-node Docker Compose set up.
2015-11-30 07:09:07 +01:00
2017-02-04 07:07:23 +01:00
### Requirements
2015-11-30 07:09:07 +01:00
2017-02-04 07:07:23 +01:00
* [docker]
* [docker-compose]
2017-01-31 01:51:36 +01:00
2017-03-13 23:26:45 +01:00
### Choose Edition to Install
If you want to install enterprise edition, you can skip this section.
To install the team edition, comment out the following line in docker-compose.yaml file:
2017-06-02 23:56:51 +02:00
```
dockerfile: Dockerfile-enterprise
```
2017-03-13 23:26:45 +01:00
2017-02-23 22:32:24 +01:00
### Database
2017-03-03 17:16:47 +01:00
Make sure to set the appropriate values for `MM_USERNAME` , `MM_PASSWORD` and `MM_DBNAME` .
2017-02-23 22:32:24 +01:00
2016-04-07 10:34:10 +02:00
### Install with SSL certificate
2015-11-30 07:09:07 +01:00
2017-02-26 09:30:03 +01:00
1. Put your SSL certificate as `./volumes/web/cert/cert.pem` and the private key that has
2016-08-12 03:38:54 +02:00
no password as `./volumes/web/cert/key-no-password.pem` . If you don't have
2016-04-07 10:34:10 +02:00
them you may generate a self-signed SSL certificate.
2015-11-30 07:09:07 +01:00
2017-03-13 23:26:45 +01:00
2. Build and run mattermost
2017-06-02 23:56:51 +02:00
```
docker-compose up -d
```
2016-04-07 10:34:10 +02:00
2017-03-13 23:26:45 +01:00
3. Open `https://your.domain` with your web browser.
2016-04-07 10:34:10 +02:00
### Install without SSL certificate
2017-02-26 09:30:03 +01:00
1. Build and run mattermost
2017-06-02 23:56:51 +02:00
```
docker-compose up -d
```
2016-04-07 10:34:10 +02:00
2017-03-13 23:26:45 +01:00
2. Open `http://your.domain` with your web browser.
2016-04-07 10:34:10 +02:00
## Starting/Stopping
### Start
2017-06-02 23:56:51 +02:00
```
docker-compose start
```
2015-11-30 07:09:07 +01:00
### Stop
2017-06-02 23:56:51 +02:00
```
docker-compose stop
```
2016-04-07 10:34:10 +02:00
2017-03-03 17:16:47 +01:00
### Update
Make sure to backup Mattermost data before proceeding.
2017-06-02 23:56:51 +02:00
```
docker-compose down
git pull
docker-compose build
docker-compose up -d
```
2017-03-03 17:16:47 +01:00
2016-04-07 10:34:10 +02:00
## Removing
2015-11-30 07:09:07 +01:00
2015-12-04 10:19:06 +01:00
### Remove the containers
2017-06-02 23:56:51 +02:00
```
docker-compose stop & & docker-compose rm
```
2015-11-30 07:09:07 +01:00
2015-12-04 10:19:06 +01:00
### Remove the data and settings of your mattermost instance
2017-06-02 23:56:51 +02:00
```
sudo rm -rf volumes
```
2015-12-04 10:19:06 +01:00
2016-04-20 05:50:19 +02:00
## Database Backup
2016-06-09 16:31:33 +02:00
When AWS S3 environment variables are specified on db docker container, it enables [Wal-E ](https://github.com/wal-e/wal-e ) backup to S3.
2016-04-20 05:50:19 +02:00
```bash
docker run -d --name mattermost-db \
-e AWS_ACCESS_KEY_ID=XXXX \
-e AWS_SECRET_ACCESS_KEY=XXXX \
-e WALE_S3_PREFIX=s3://BUCKET_NAME/PATH \
-e AWS_REGION=us-east-1
-v ./volumes/db/var/lib/postgresql/data:/var/lib/postgresql/data
-v /etc/localtime:/etc/localtime:ro
db
```
All four environment variables are required. It will enable completed WAL segments sent to archive storage (S3). The base backup and clean up can be done through the following command:
```bash
# base backup
docker exec mattermost-db su - postgres sh -c "/usr/bin/envdir /etc/wal-e.d/env /usr/local/bin/wal-e backup-push /var/lib/postgresql/data"
# keep the most recent 7 base backups and remove the old ones
docker exec mattermost-db su - postgres sh -c "/usr/bin/envdir /etc/wal-e.d/env /usr/local/bin/wal-e delete --confirm retain 7"
```
Those tasks can be executed through a cron job or systemd timer.
2017-02-23 06:37:43 +01:00
## Customization
Customization can be done through environment variables.
### Mattermost App Image
2017-06-02 23:56:51 +02:00
* `MM_USERNAME` : database username, must be the same as one in DB image
* `MM_PASSWORD` : database password, must be the same as one in DB image
* `MM_DBNAME` : database name, must be the same as one in DB image
* `DB_HOST` : database host address
2017-06-07 22:48:41 +02:00
* `DB_PORT_NUMBER` : database port
2017-06-02 23:56:51 +02:00
* `MM_CONFIG` : configuration file location. It can be used when config is mounted in a different location.
2017-02-23 06:37:43 +01:00
### Mattermost DB Image
2017-06-02 23:56:51 +02:00
* `MM_USERNAME` : database username, must be the same as on in App image
* `MM_PASSWORD` : database password, must be the same as on in App image
* `MM_DBNAME` : database name, must be the same as on in App image
* `AWS_ACCESS_KEY_ID` : aws access key, used for db backup
* `AWS_SECRET_ACCESS_KEY` : aws secret, used for db backup
* `WALE_S3_PREFIX` : aws s3 bucket name, used for db backup
* `AWS_REGION` : aws region, used for db backup
2017-02-23 06:37:43 +01:00
### Mattermost Web Image
2017-06-02 23:56:51 +02:00
* `MATTERMOST_ENABLE_SSL` : whether to enable SSL
* `PLATFORM_PORT_80_TCP_PORT` : port that Mattermost image is listening on
2017-02-23 06:37:43 +01:00
2016-05-17 14:20:41 +02:00
## Upgrading to Team Edition 3.0.x from 2.x
You need to migrate your database before upgrading mattermost to 3.0.x from
2.x. Run these commands in the latest mattermost-docker directory.
2017-06-02 23:56:51 +02:00
```
docker-compose rm -f app
docker-compose build app
docker-compose run app -upgrade_db_30
docker-compose up -d
```
2016-05-17 14:20:41 +02:00
See the [offical Upgrade Guide ](http://docs.mattermost.com/administration/upgrade.html ) for more details.
2015-12-03 16:40:11 +01:00
## Known Issues
* Do not modify the Listen Address in Service Settings.
2015-12-09 09:17:25 +01:00
* Rarely 'app' container fails to start because of "connection refused" to
2015-12-04 10:20:00 +01:00
database. Workaround: Restart the container.
2015-12-03 16:40:11 +01:00
2017-02-04 07:07:23 +01:00
## More information
2015-11-30 07:09:07 +01:00
If you want to know how to use docker-compose, see [the overview
page](https://docs.docker.com/compose).
2016-04-17 11:37:57 +02:00
For the server configurations, see [prod-ubuntu.rst] of mattermost.
2015-11-30 07:09:07 +01:00
[docker]: http://docs.docker.com/engine/installation/
[docker-compose]: https://docs.docker.com/compose/install/
2017-01-27 15:25:58 +01:00
[prod-ubuntu.rst]: https://docs.mattermost.com/install/install-ubuntu-1404.html