Найти тему
Имя на Яндексе

Настройка ssl в ngix для Rocket.Chat

Настройка доступа к чату по https - как джва пальца...
Настройка доступа к чату по https - как джва пальца...

Условия такие:

  1. Уже есть ключи выданные провайдером (у меня wildcard от comodo), нужны *.key и *.crt, я положил их в домашнюю директорию пользователя на сервере чата
  2. В DNS создана зона для сервера чата (я сделал chat.my-domain.ru и указал А-запись на ip сервера)

Лезем в консоль сервера (как установить Rocket.Chat на Ubuntu Server можно почитать тут), устанавливаем nginx:

sudo su
apt install -y nginx

Веб-сервер установился, теперь накидаем ключи в его каталог:

cp ~user/commercial.key /etc/nginx/certificate.key
chmod 400 /etc/nginx/certificate.key
cp STAR_my-domain_ru.crt /etc/nginx/certificate.crt

После этого удаляем настройку по умолчанию и создаем новую:

rm /etc/nginx/sites-enabled/default
nano /etc/nginx/sites-enabled/default

Просто копипастите текст и меняете chat.my-domain.ru на свой домен:

server {
listen 443;
server_name chat.my-domain.ru
error_log /var/log/nginx/rocketchat.access.log;
ssl on;
ssl_certificate /etc/nginx/certificate.crt;
ssl_certificate_key /etc/nginx/certificate.key;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # don’t use SSLv3 ref: POODLE
location / {
proxy_pass
http://chat.my-domain.ru :3000/;
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;
}
}

Перезапускаем службу и проверяем работает ли она:

service nginx restart
service nginx status

И всё. Теперь чат доступен по адресу https://chat.my-domain.ru