
Mattermost — это платформа для обмена мгновенными сообщениями с открытым исходным кодом, альтернатива Slack, размещаемая на собственном сервере. Она написана на Golang и React и может использовать MySQL или PostgreSQL в качестве бэкенда базы данных. Mattermost объединяет все коммуникационные возможности вашей команды и предоставляет различные функции, включая обмен файлами, личные и групповые сообщения, пользовательские эмодзи, видеозвонки и многое другое. В этом руководстве мы покажем вам, как развернуть Mattermost на сервере CentOS 7 и настроить Nginx в качестве обратного прокси-сервера SSL.
Предпосылки
Прежде чем продолжить изучение этого руководства, убедитесь, что выполнены следующие предварительные условия:
- Вы вошли в систему как пользователь с привилегиями sudo .
- У вас есть доменное имя, указывающее на IP-адрес вашего сервера. Мы будем использовать
linuxize-test.com. - У вас установлен Nginx, если нет, проверьте это руководство.
- Для вашего домена установлен SSL-сертификат. Вы можете установить бесплатный SSL-сертификат Let's Encrypt, следуя этому руководству.
Создать базу данных MySQL
В качестве бэкэнда мы будем использовать MariaDB 10.3. Mattermost не будет работать с MariaDB версии 5.5.
Если на вашем сервере не установлена MariaDB 10.3, вы можете обратиться к этому руководству .
Войдите в оболочку MySQL:
mysql -u root -p
И выполните следующие команды, чтобы создать новую базу данных и пользователя для нашей установки Mattermost:
create database mattermost;GRANT ALL ON mattermost.* TO mattermost@localhost IDENTIFIED BY 'P4ssvv0rD';
Создать нового пользователя системы
Чтобы создать нового пользователя и группу с именем mattermost , которые будут запускать установку Mattermost, выполните следующую команду:
sudo useradd -U -M -d /opt/mattermost mattermost
Установить Mattermost Server
На момент написания этой статьи последней стабильной версией Mattermost была версия 5.4.0. Прежде чем перейти к следующему шагу, проверьте страницу загрузки Mattermost, чтобы узнать, доступна ли более новая версия.
Загрузите архив с помощью следующей команды curl :
sudo curl -L https://releases.mattermost.com/5.4.0/mattermost-5.4.0-linux-amd64.tar.gz -o /tmp/mattermost.tar.gz
После завершения загрузки извлеките архив и переместите его в каталог opt :
sudo tar zxf /tmp/mattermost.tar.gz -C /opt
Создайте каталог хранения файлов:
sudo mkdir /opt/mattermost/data
Измените владельца каталога на пользователя mattermost :
sudo chown -R mattermost: /opt/mattermost
Откройте файл config.json с помощью вашего любимого текстового редактора :
sudo nano /opt/mattermost/config/config.json
Установите драйвер базы данных на mysql , введите имя базы данных и пароль пользователя базы данных, которые мы создали ранее в этом руководстве:
/opt/mattermost/config/config.json
... "SqlSettings" : { "DriverName" : "mysql" , "DataSource" : "mattermost:P4ssvv0rD@tcp(localhost:3306)/mattermost?charset=utf8mb4,utf8&readTimeout=30s&writeTimeout=30s" , "DataSourceReplicas" : [], ...
Чтобы протестировать нашу установку и убедиться, что все работает, перед созданием модуля systemd и настройкой обратного прокси-сервера с Nginx, мы запустим сервер Mattermost.
Перейдите в каталог /opt/mattermost и запустите сервер:
cd /opt/mattermostsudo -u mattermost bin/mattermost
Вывод должен показать, что сервер Mattermost прослушивает порт 8065 :
{"level":"info","ts":1540921243.6797202,"caller":"app/plugin.go:100","msg":"Starting up plugins"} {"level":"info","ts":1540921244.3483207,"caller":"app/server.go:88","msg":"Starting Server..."} {"level":"info","ts":1540921244.3488805,"caller":"app/server.go:148","msg":"Server is listening on [::]:8065"} {"level":"info","ts":1540921244.3620636,"caller":"app/web_hub.go:75","msg":"Starting 2 websocket hubs"} {"level":"info","ts":1540921244.451155,"caller":"jobs/workers.go:63","msg":"Starting workers"} {"level":"info","ts":1540921244.456804,"caller":"jobs/schedulers.go:68","msg":"Starting schedulers."}
Теперь вы можете остановить сервер Mattermost с помощью CTRL+C и перейти к следующим шагам.
Создать системный модуль
Чтобы запустить наш экземпляр Mattermost как службу, мы создадим файл модуля mattermost.service в каталоге /etc/systemd/system/ со следующим содержимым:
/etc/systemd/system/mattermost.service
[Unit] Description = Mattermost After = network.target nss-lookup.target mariadb.service [Service] Type = notify WorkingDirectory = /opt/mattermost User = mattermost SyslogIdentifier = mattermost ExecStart = /opt/mattermost/bin/mattermost TimeoutStartSec = 3600 LimitNOFILE = 49152 [Install] WantedBy = multi-user.target
Сообщите systemd о том, что мы создали новый файл модуля и запустите службу Mattermost, выполнив:
sudo systemctl daemon-reloadsudo systemctl start mattermost
Теперь мы можем проверить состояние службы с помощью следующей команды:
sudo systemctl status mattermost
● mattermost.service - Mattermost Loaded: loaded (/etc/systemd/system/mattermost.service; disabled; vendor preset: disabled) Active: active (running) since Tue 2018-10-30 17:44:46 UTC; 3s ago Main PID: 25959 (mattermost) CGroup: /system.slice/mattermost.service └─25959 /opt/mattermost/bin/mattermost
Наконец, включите автоматический запуск службы Mattermost при загрузке:
sudo systemctl enable mattermost
Настройка обратного прокси-сервера с помощью Nginx
Если вы следовали нашим руководствам по установке Nginx на CentOS 7 и защите Nginx с помощью Let's Encrypt на CentOS 7, у вас уже должен быть установлен и настроен Nginx с SSL-сертификатом. Теперь нам нужно только создать новый серверный блок для установки Mattermost.
/etc/nginx/conf.d/linuxize-test.com.conf
proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=mattermost_cache:10m max_size=3g inactive=120m use_temp_path=off ; upstream mattermost_backend { server 127.0.0.1 : 8065 ; } server { listen 80 ; server_name linuxize-test.com www.linuxize-test.com ; include snippets/letsencrypt.conf ; return 301 https://linuxize-test.com $request_uri ; } server { listen 443 ssl http2 ; server_name www.linuxize-test.com ; ssl_certificate /etc/letsencrypt/live/linuxize-test.com/fullchain.pem ; ssl_certificate_key /etc/letsencrypt/live/linuxize-test.com/privkey.pem ; ssl_trusted_certificate /etc/letsencrypt/live/linuxize-test.com/chain.pem ; include snippets/ssl.conf ; return 301 https://linuxize-test.com $request_uri ; } server { listen 443 ssl http2 ; server_name linuxize-test.com ; ssl_certificate /etc/letsencrypt/live/linuxize-test.com/fullchain.pem ; ssl_certificate_key /etc/letsencrypt/live/linuxize-test.com/privkey.pem ; ssl_trusted_certificate /etc/letsencrypt/live/linuxize-test.com/chain.pem ; include snippets/ssl.conf ; access_log /var/log/nginx/linuxize-test.com-access.log ; error_log /var/log/nginx/linuxize-test.com-error.log ; location ~ /api/v[0-9]+/(users/)?websocket$ { proxy_set_header Upgrade $http_upgrade ; proxy_set_header Connection "upgrade" ; client_max_body_size 50M ; proxy_set_header Host $http_host ; proxy_set_header X-Real-IP $remote_addr ; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for ; proxy_set_header X-Forwarded-Proto $scheme ; proxy_set_header X-Frame-Options SAMEORIGIN ; proxy_buffers 256 16k ; proxy_buffer_size 16k ; proxy_read_timeout 600s ; proxy_pass http://mattermost_backend ; } location / { proxy_http_version 1 .1 ; client_max_body_size 50M ; proxy_set_header Connection "" ; proxy_set_header Host $http_host ; proxy_set_header X-Real-IP $remote_addr ; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for ; proxy_set_header X-Forwarded-Proto $scheme ; proxy_set_header X-Frame-Options SAMEORIGIN ; proxy_buffers 256 16k ; proxy_buffer_size 16k ; proxy_read_timeout 600s ; proxy_cache mattermost_cache ; proxy_cache_revalidate on ; proxy_cache_min_uses 2 ; proxy_cache_use_stale timeout ; proxy_cache_lock on ; proxy_pass http://mattermost_backend ; } }
Перезагрузите службу Nginx , чтобы изменения вступили в силу:
sudo systemctl reload nginx
Настройка Mattermost
Откройте браузер, введите свой домен и создайте свою первую учетную запись:

Первый созданный пользователь в системе имеет права администратора.

Нажмите ссылку Create a new team , создайте свою первую команду и укажите URL-адрес команды:


После создания первой учётной записи администратора и первой команды вы будете перенаправлены на панель управления Mattermost, войдя в неё как администратор. Откройте системную консоль, нажав на своё имя пользователя в верхней части навигационной панели, и в открывшемся меню выберите ссылку System Console :

Задайте URL-адрес сайта, перейдя в раздел Настройки Общие → Конфигурация.

Включите уведомления по электронной почте, перейдя в раздел Уведомления → Электронная почта.

и введите параметры SMTP. Вы можете использовать любой популярный сервис транзакционной почты, такой как SendinBlue, SendGrid, Amazon SES, Mandrill, Mailgun, Mailjet и Postmark, или настроить собственный почтовый сервер .
Наконец, нам необходимо перезапустить службу Mattermost, чтобы изменения вступили в силу:
sudo systemctl restart mattermost
Заключение
Вы успешно установили Mattermost на свой сервер CentOS 7 и настроили Nginx в качестве обратного прокси-сервера. Теперь вы можете начать использовать Mattermost для совместной работы с вашей командой.
Если у вас возникли проблемы с установкой, не стесняйтесь оставлять комментарии.
mattermost nodejs centos Не используете CentOS 7?
Выберите другую ОС: убунту 18.04
Связанные руководства