Cómo instalar Mattermost en Debian 11

Mattermost es una plataforma de colaboración y mensajería gratuita y de código abierto creada pensando en la seguridad. Es una alternativa a Discord o Slack y ofrece muchas funciones útiles, entre ellas, mensajería individual, historial de búsqueda ilimitado y capacidad de compartir archivos, autorización de dos factores y notificaciones. Es un servicio de chat online autoalojado escrito en Golang y React. Está especialmente diseñado para organizaciones y empresas y permite a los equipos comunicarse de forma segura desde cualquier lugar.

En este tutorial, te mostraremos cómo instalar el servidor de Mattermost Chat en Debian 11.

Requisitos previos

  • Un servidor con Debian 11.
  • Un nombre de dominio válido apuntado con la IP de tu servidor.
  • Una contraseña de root configurada en el servidor.

Instalar y configurar el servidor de base de datos MariaDB

Mattermost utiliza MySQL o MariaDB como base de datos. Así que tendrás que instalar el servidor MariaDB en tu servidor. Puedes instalarlo con el siguiente comando:

apt-get install mariadb-server -y

Una vez instalado MariaDB, inicia el servicio MariaDB y habilítalo para que se inicie al reiniciar el sistema:

systemctl start mariadb
systemctl enable mariadb

A continuación, conéctate al shell de MariaDB con el siguiente comando:

mysql

Una vez conectado, crea una base de datos y un usuario con el siguiente comando:

MariaDB [(none)]> create database mattermost;
MariaDB [(none)]> create user mattermost@localhost identified by 'password';

A continuación, concede todos los privilegios a la base de datos Mattermost con el siguiente comando:

MariaDB [(none)]> grant all privileges on mattermost.* to mattermost@localhost;

A continuación, vacía los privilegios y sal del intérprete de comandos MariaDB con el siguiente comando:

MariaDB [(none)]> flush privileges;
MariaDB [(none)]> exit;

Una vez que hayas terminado, puedes pasar al siguiente paso.

Instalar Mattermost

En primer lugar, crea un usuario dedicado para Mattermost con el siguiente comando:

useradd --system --user-group mattermost

A continuación, descarga la última versión de Mattermost con el siguiente comando:

wget https://releases.mattermost.com/6.0.2/mattermost-6.0.2-linux-amd64.tar.gz

Una vez completada la descarga, extrae el archivo descargado con el siguiente comando:

tar -xvzf mattermost-6.0.2-linux-amd64.tar.gz

A continuación, mueve el directorio extraído a /opt con el siguiente comando:

mv mattermost /opt

A continuación, crea un directorio de datos para mattermost con el siguiente comando:

mkdir /opt/mattermost/data

A continuación, cambia la propiedad del directorio mattermost con el siguiente comando

chown -R mattermost:mattermost /opt/mattermost
chmod -R g+w /opt/mattermost

A continuación, edita el archivo config.json con el siguiente comando

nano /opt/mattermost/config/config.json

Busca las siguientes líneas:

    "DriverName": "postgres",
    "DataSource": "postgres://mmuser:mostest@localhost/mattermost_test?sslmode=disable\u0026connect_timeout=10",

Y, sustitúyelas por las siguientes líneas según la configuración de tu base de datos:

"DriverName": "mysql",
"DataSource": "mattermost:password@tcp(127.0.0.1:3306)/mattermost?charset=utf8mb4,utf8\u0026readTimeout=30s\u0026writeTimeout=30s",

Guarda y cierra el archivo cuando hayas terminado.

Crear un archivo de servicio Systemd para Mattermost

A continuación, tendrás que crear un archivo de servicio systemd para Mattermost. Puedes crearlo con el siguiente comando:

nano /etc/systemd/system/mattermost.service

Añade las siguientes líneas:

[Unit]
Description=Mattermost
After=syslog.target network.target mysqld.service

[Service]
Type=notify
WorkingDirectory=/opt/mattermost
User=mattermost
ExecStart=/opt/mattermost/bin/mattermost
PIDFile=/var/spool/mattermost/pid/master.pid
TimeoutStartSec=3600
LimitNOFILE=49152

[Install]
WantedBy=multi-user.target

Guarda y cierra el archivo y vuelve a cargar el demonio systemd para aplicar los cambios:

systemctl daemon-reload

A continuación, inicia el Mattermost y habilítalo para que se inicie al reiniciar el sistema:

systemctl start mattermost
systemctl enable mattermost

A continuación, verifica el estado de Mattermost con el siguiente comando:

systemctl status mattermost

Obtendrás la siguiente salida:

? mattermost.service - Mattermost
     Loaded: loaded (/etc/systemd/system/mattermost.service; disabled; vendor preset: enabled)
     Active: active (running) since Fri 2021-11-12 13:56:25 UTC; 4s ago
   Main PID: 2888 (mattermost)
      Tasks: 31 (limit: 4679)
     Memory: 273.3M
        CPU: 12.191s
     CGroup: /system.slice/mattermost.service
             ??2888 /opt/mattermost/bin/mattermost
             ??2915 plugins/com.mattermost.plugin-channel-export/server/dist/plugin-linux-amd64
             ??2925 plugins/playbooks/server/dist/plugin-linux-amd64
             ??2931 plugins/focalboard/server/dist/plugin-linux-amd64

Nov 12 13:56:24 debian11 mattermost[2888]: {"timestamp":"2021-11-12 13:56:24.681 Z","level":"info","msg":"Scheduling next survey for Dec 3, 2>
Nov 12 13:56:25 debian11 mattermost[2888]: {"timestamp":"2021-11-12 13:56:25.064 Z","level":"info","msg":"Post.Message has size restrictions">
Nov 12 13:56:25 debian11 mattermost[2888]: {"timestamp":"2021-11-12 13:56:25.084 Z","level":"info","msg":"info [2021-11-12 13:56:25.083 Z] co>
Nov 12 13:56:25 debian11 mattermost[2888]: {"timestamp":"2021-11-12 13:56:25.131 Z","level":"info","msg":"\n    -- collation of mattermost's >
Nov 12 13:56:25 debian11 mattermost[2888]: {"timestamp":"2021-11-12 13:56:25.491 Z","level":"info","msg":"debug [2021-11-12 13:56:25.488 Z] i>
Nov 12 13:56:25 debian11 mattermost[2888]: {"timestamp":"2021-11-12 13:56:25.777 Z","level":"info","msg":"info [2021-11-12 13:56:25.777 Z] Se>
Nov 12 13:56:25 debian11 mattermost[2888]: {"timestamp":"2021-11-12 13:56:25.963 Z","level":"info","msg":"Starting Server...","caller":"app/s>
Nov 12 13:56:25 debian11 mattermost[2888]: {"timestamp":"2021-11-12 13:56:25.964 Z","level":"info","msg":"Server is listening on [::]:8065",">
Nov 12 13:56:25 debian11 mattermost[2888]: {"timestamp":"2021-11-12 13:56:25.964 Z","level":"info","msg":"Sending systemd READY notification.>
Nov 12 13:56:25 debian11 systemd[1]: Started Mattermost.

Configurar Nginx como proxy inverso para Mattermost

Por defecto, Mattermost escucha en el puerto 8065. Así que es una buena idea instalar y configurar el Nginx como proxy inverso para acceder a Mattermost en el puerto 80. Primero, instala el Nginx con el siguiente comando:

apt-get install nginx -y

Una vez instalado el Nginx, crea un archivo de configuración del host virtual Nginx con el siguiente comando:

nano /etc/nginx/conf.d/mattermost.conf

Añade las siguientes líneas:

upstream mattermost {
   server localhost:8065;
   keepalive 32;
}

proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=mattermost_cache:10m max_size=3g inactive=120m use_temp_path=off;

server {
   listen 80;
   server_name mattermost.example.com;

   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;
       client_body_timeout 60;
       send_timeout 300;
       lingering_timeout 5;
       proxy_connect_timeout 90;
       proxy_send_timeout 300;
       proxy_read_timeout 90s;
       proxy_pass http://mattermost;
   }

   location / {
       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_http_version 1.1;
       proxy_pass http://mattermost;
   }
}

Guarda y cierra el archivo y luego verifica la configuración de Nginx para ver si hay algún error de sintaxis con el siguiente comando:

nginx -t

Deberías ver la siguiente salida:

nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful

A continuación, inicia el servicio Nginx para aplicar los cambios:

systemctl start nginx

También puedes verificar el estado de Nginx con el siguiente comando:

systemctl status nginx

Deberías obtener la siguiente salida:

? nginx.service - A high performance web server and a reverse proxy server
     Loaded: loaded (/lib/systemd/system/nginx.service; enabled; vendor preset: enabled)
     Active: active (running) since Fri 2021-11-12 13:57:02 UTC; 1min 12s ago
       Docs: man:nginx(8)
    Process: 3384 ExecStartPre=/usr/sbin/nginx -t -q -g daemon on; master_process on; (code=exited, status=0/SUCCESS)
    Process: 3392 ExecStart=/usr/sbin/nginx -g daemon on; master_process on; (code=exited, status=0/SUCCESS)
   Main PID: 3602 (nginx)
      Tasks: 3 (limit: 4679)
     Memory: 6.6M
        CPU: 55ms
     CGroup: /system.slice/nginx.service
             ??3602 nginx: master process /usr/sbin/nginx -g daemon on; master_process on;
             ??3604 nginx: worker process
             ??3605 nginx: worker process

Nov 12 13:57:01 debian11 systemd[1]: Starting A high performance web server and a reverse proxy server...
Nov 12 13:57:02 debian11 systemd[1]: nginx.service: Failed to parse PID from file /run/nginx.pid: Invalid argument
Nov 12 13:57:02 debian11 systemd[1]: Started A high performance web server and a reverse proxy server.

En este punto, Nginx está instalado y configurado como proxy inverso para Mattermost. Ahora puedes pasar al siguiente paso.

Accede a la interfaz web de Mattermost

Ahora, abre tu navegador web y accede a la interfaz web de Mattermost utilizando la URL http://mattermost.example.com. Serás redirigido a la siguiente página:

Inicio de sesión en Mattermost

Proporciona tu dirección de correo electrónico de administrador, tu nombre de usuario y tu contraseña, y haz clic en el botón Crear cuenta. Deberías ver la siguiente página:

Mattermost

Ahora, haz clic en el botón Ir a la consola del sistema. Serás redirigido al panel de control de Mattermost como se muestra a continuación:

Panel de control de Mattermost

Conclusión

Enhorabuena! has instalado con éxito Mattermost con Nginx como proxy inverso en Debian 11. Ahora puedes implementar Mattermost en tu organización y permitir que los equipos se comuniquen entre sí desde cualquier lugar.

También te podría gustar...