如何在CentOS 7上部署Mattermost

Mattermost是一個開放源代碼的即時消息傳遞平台,它是自託管的Slack替代產品。 它是用Golang和React編寫的,可以將MySQL或PostgreSQL用作數據庫後端。 Mattermost將您所有團隊的溝通融合到一處,並提供各種功能,包括文件共享,一對一和組消息傳遞,自定義表情符號,視頻通話等。 在本教程中,我們將向您展示如何在CentOS 7服務器上部署Mattermost以及如何將Nginx配置為SSL反向代理。

先決條件

在繼續本教程之前,請確保您已滿足以下先決條件:

  • 您以具有sudo特權的用戶身份登錄。
  • 您有一個指向服務器IP地址的域名。 我們將使用 linuxize-test.com
  • 您已經安裝了Nginx,如果沒有,請查看本指南。
  • 您已經為您的域安裝了SSL證書。 您可以按照本指南安裝免費的“讓我們加密SSL”證書。

創建MySQL數據庫

我們將使用MariaDB 10.3作為數據庫後端。 Mattermost不適用於MariaDB 5.5版。

如果您的服務器上未安裝MariaDB 10.3,則可以查看本指南。

登錄到MySQL Shell:

mysql -u root -p

並運行以下命令為Mattermost安裝創建新的數據庫和用戶:

create database mattermost;GRANT ALL ON mattermost.* TO [email protected] IDENTIFIED BY 'P4ssvv0rD';

創建新的系統用戶#

創建一個名為的新用戶和組 mattermost,它將運行Mattermost安裝,請運行以下命令:

sudo useradd -U -M -d /opt/mattermost mattermost

安裝Mattermost服務器#

在撰寫本文時,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:[email protected](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設置反向代理

如果遵循我們如何在CentOS 7上安裝Nginx以及如何在CentOS 7上使用“讓我們加密”來保護Nginx,則您應該已經安裝了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團隊網址

創建第一個管理員帳戶和第一個團隊後,您將被重定向到Mattermost儀錶板,以管理員身份登錄。 通過單擊導航面板頂部的用戶名,打開系統控制台,然後在打開的新菜單中,單擊 System Console 鏈接:

最重要的儀錶板

通過轉到設置常規→配置來設置站點URL。

最重要的設置

通過轉到通知→電子郵件來啟用電子郵件通知

最重要的通知

並輸入您的SMTP參數。 您可以使用任何流行的交易電子郵件服務,例如SendinBlue,SendGrid,Amazon SES,Mandrill,Mailgun,Mailjet和Postmark,也可以設置自己的郵件服務器。

最後,我們需要重新啟動Mattermost服務以使更改生效:

sudo systemctl restart mattermost

結論#

您已在CentOS 7服務器上成功安裝了Mattermost,並將Nginx設置為反向代理。 您現在可以開始使用Mattermost與您的團隊進行協作。

如果您在安裝過程中遇到任何問題,請隨時發表評論。

最重要的nodejs centos

Sidebar