Как развернуть Rocket.Chat на CentOS 7

Rocket.Chat — это полноценная командная коммуникационная платформа, альтернатива Slack с собственным хостингом. Он построен на Meteor и предоставляет различные функции, включая чат службы поддержки, видеоконференцсвязь, совместное использование файлов, голосовые сообщения, API и многое другое.

В этом руководстве мы покажем вам, как установить и развернуть Rocket.Chat на сервере CentOS 7 с Nginx в качестве обратного прокси-сервера SSL.

Подготовка

Прежде чем продолжить работу с этим руководством, убедитесь, что вы выполнили следующие предварительные требования:

  • Сервер CentOS 7, согласно официальным системным требованиям Rocket.Chat, вам потребуется как минимум 1 ГБ оперативной памяти.
  • Вы вошли в систему как пользователь с привилегиями sudo .
  • У вас есть доменное имя, указывающее на IP-адрес вашего сервера. В этой статье мы будем использовать example.com .
  • У вас установлен Nginx, если нет, вы можете установить его, следуя этому руководству.
  • Сертификат SSL. Вы можете создать его бесплатно в Let's Encrypt или купить у другого провайдера.

Установить зависимости

Установите следующие пакеты, которые необходимы для сборки необходимых модулей npm :

sudo yum install epel-release curl GraphicsMagick gcc-c++

Затем установите Node.js и npm , набрав:

sudo yum install -y nodejs npm

На момент написания этой статьи рекомендуемая версия Node.js для Rocket.Chat — Node.js v8.11.3.

Выполните следующие команды, чтобы установить утилиту n и рекомендуемую версию Node.js:

sudo npm install -g inherits nsudo n 8.11.3

MongoDB — это документно-ориентированная база данных NoSQL, которая используется Rocket.Chat в качестве хранилища данных. Rocket.Chat рекомендует MongoDB версии 3.6.

Мы установим MongoDB, используя yum из официальных репозиториев MongoDB.

Откройте нужный редактор и создайте следующий файл репозитория:

sudo nano /etc/yum.repos.d/mongodb-org.repo

Вставьте в файл следующее содержимое:

/etc/yum.repos.d/mongodb-org.repo
[mongodb-org-3.6]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/3.6/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-3.6.asc

Сохраните файл и закройте текстовый редактор .

Чтобы установить MongoDB, выполните следующую команду:

sudo yum install mongodb-org

После завершения установки включите и запустите службу MongoDB:

sudo systemctl start mongodsudo systemctl enable mongod

Создать нового системного пользователя

Создайте нового пользователя и группу, которые будут запускать наш экземпляр Rocket.Chat. Для простоты назовем пользовательскую rocket :

sudo useradd -m -U -r -d /opt/rocket rocket

Добавьте пользователя nginx в новую группу пользователей и измените права доступа к каталогу /opt/rocket чтобы Nginx мог получить к нему доступ:

sudo usermod -a -G rocket nginxsudo chmod 750 /opt/rocket

Установка Rocket.Chat

Переключитесь на пользовательскую rocket , набрав:

sudo su - rocket

Загрузите последнюю стабильную версию Rocket.Chat с помощью curl :

curl -L https://releases.rocket.chat/latest/download -o rocket.chat.tgz

После завершения загрузки извлеките архив и переименуйте каталог в Rocket.Chat :

tar zxf rocket.chat.tgzmv bundle Rocket.Chat

Перейдите в каталог Rocket.Chat/programs/server и установите все необходимые пакеты npm :

cd Rocket.Chat/programs/servernpm install

Перед созданием модуля systemd и настройкой обратного прокси с Nginx рекомендуется проверить, была ли установка успешной.

Для этого начните с установки необходимых переменных среды:

export PORT=3000export ROOT_URL=http://example.com:3000/export MONGO_URL=mongodb://localhost:27017/rocketchat

Затем вернитесь в каталог Rocket.Chat и запустите сервер Rocket.Chat следующие команды:

cd ../../node main.js

Если ошибок нет, вы должны увидеть следующий вывод:

➔ +---------------------------------------------+
➔ |                SERVER RUNNING               |
➔ +---------------------------------------------+
➔ |                                             |
➔ |  Rocket.Chat Version: 0.71.1                |
➔ |       NodeJS Version: 8.11.3 - x64          |
➔ |             Platform: linux                 |
➔ |         Process Port: 3000                  |
➔ |             Site URL: http://0.0.0.0:3000/  |
➔ |     ReplicaSet OpLog: Disabled              |
➔ |          Commit Hash: e73dc78ffd            |
➔ |        Commit Branch: HEAD                  |
➔ |                                             |
➔ +---------------------------------------------+

На этом этапе Rocket.Chat установлен на вашем компьютере с CentOS 7. Остановите сервер Rocket.Chat с помощью CTRL+C и перейдите к следующим шагам.

Создать Systemd Unit

Чтобы запустить Rocket.Chat как службу, создайте rocketchat.service модуля rocketchat.service каталоге /etc/systemd/system/ :

sudo nano /etc/systemd/system/rocketchat.service

Вставьте в файл следующее содержимое:

/etc/systemd/system/rocketchat.service
[Unit]
Description=Rocket.Chat server
After=network.target nss-lookup.target mongod.target

[Service]
StandardOutput=syslog
StandardError=syslog
SyslogIdentifier=rocketchat
User=rocket
Environment=MONGO_URL=mongodb://localhost:27017/rocketchat ROOT_URL=http://example.com:3000/ PORT=3000
ExecStart=/usr/local/bin/node /opt/rocket/Rocket.Chat/main.js

[Install]
WantedBy=multi-user.target

Сохраните и закройте файл.

Сообщите systemd о том, что был создан новый файл модуля, и запустите службу Rocket.Chat, выполнив:

sudo systemctl daemon-reloadsudo systemctl start rocketchat

Проверьте статус службы с помощью следующей команды:

sudo systemctl status rocketchat

Результат должен выглядеть примерно так:

● rocketchat.service - Rocket.Chat server
   Loaded: loaded (/etc/systemd/system/rocketchat.service; enabled; vendor preset: disabled)
   Active: active (running) since Tue 2018-04-10 20:30:56 UTC; 8s ago
 Main PID: 32356 (node)
   CGroup: /system.slice/rocketchat.service
           └─32356 /usr/local/bin/node /opt/rocket/Rocket.Chat/main.js

Если ошибок нет, вы можете включить автоматический запуск службы Rocket.Chat при загрузке:

sudo systemctl enable rocketchat

Настройте обратный прокси с Nginx

Если вы следовали нашим инструкциям по установке Nginx в CentOS 7 и защите Nginx с помощью Let's Encrypt в CentOS 7, у вас уже должен быть установлен и настроен Nginx с сертификатом SSL.

Теперь нам нужно создать новый серверный блок для нашей установки Rocket.Chat:

sudo nano /etc/nginx/conf.d/example.com.conf

Вставьте в файл следующее содержимое:

/etc/nginx/conf.d/example.com.conf
upstream rocketchat_backend {
  server 127.0.0.1:3000;
}

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

    include snippets/letsencrypt.conf;
    return 301 https://example.com$request_uri;
}

server {
    listen 443 ssl http2;
    server_name www.example.com;

    ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem;
    ssl_trusted_certificate /etc/letsencrypt/live/example.com/chain.pem;
    include snippets/ssl.conf;

    return 301 https://example.com$request_uri;
}

server {
    listen 443 ssl http2;
    server_name example.com;

    ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem;
    ssl_trusted_certificate /etc/letsencrypt/live/example.com/chain.pem;
    include snippets/ssl.conf;
    include snippets/letsencrypt.conf;

    access_log /var/log/nginx/example.com-access.log;
    error_log /var/log/nginx/example.com-error.log;

    location / {
        proxy_pass http://rocketchat_backend/;
        proxy_http_version 1.1;
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection "upgrade";
        proxy_set_header Host $http_host;

        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forward-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forward-Proto http;
        proxy_set_header X-Nginx-Proxy true;

        proxy_redirect off;
    }
}

Перезагрузите службу Nginx, чтобы изменения вступили в силу:

sudo systemctl reload nginx

Настройка Rocket.Chat

Откройте браузер и введите: http://chat.example.com .

Предполагая, что установка прошла успешно, вам будет представлен мастер установки Rocket.Chat, который проведет вас через настройку вашего первого пользователя-администратора, настройку вашей организации и регистрацию вашего сервера для получения бесплатных push-уведомлений и многое другое.

В первом разделе мастера начальной настройки вам будет предложено настроить пользователя с правами администратора:

Когда вы закончите вводить информацию об администраторе, нажмите кнопку « Continue и на следующем шаге введите информацию о вашей организации:

В третьем разделе мастера начальной настройки вам будет предложено ввести информацию о сервере:

На следующем шаге вас спросят, хотите ли вы использовать предварительно настроенные шлюзы и прокси Rocket.Chat. Выбор этой опции предоставит вам доступ к торговой площадке Rocket.Chat Apps, а большинство других функций, таких как push-уведомления, будут работать сразу после установки.

Сделайте свой выбор, нажмите кнопку « Continue , и вы будете перенаправлены на следующую страницу, указывающую, что ваше рабочее пространство готово к использованию:

Нажмите кнопку « Go to your workspace , и вы будете перенаправлены на панель управления Rocket.Chat, в которой вы вошли как пользователь с правами администратора.

Выводы

Вы успешно установили Rocket.Chat на свой сервер CentOS 7. Теперь вы можете начать использовать Rocket.Chat, чтобы сотрудничать со своей командой, обмениваться файлами и общаться в чате в реальном времени.

Если у вас возникли проблемы с установкой, не стесняйтесь оставлять комментарии.

Оставьте комментарий