В последнем обнволении Beget сделал предустановку n8n сразу на VPS без каких либо настроек. Пользуйтесь!
Процесс установки я буду показывать на примере хостинга Beget.
Заходим в панель управления хостингом в раздел облако.
Нажимаем кнопку создать => виртуальный сервер.
Выбираем самый дешевый тариф за 7р в день. (210р в месяц)
Указываем операционную систему Ubuntu версии 22.04
Нажимаем кнопку «cоздать виртуальный сервер».
После успешного создания сервера на ваш почтовый адрес придут данные для подключения.
Скачиваете программу WinSCP для удобного подключения к серверу и работы через командную строку - https://winscp.net/eng/download.php
Подключаемся к нашему серверу с помощью программы PuTTY.
Поочередно вводим указанные ниже команды в консоль.
Далее вводите все команды по очереди
apt update
apt install apt-transport-https ca-certificates curl software-properties-common -y
curl -fsSL <https://download.docker.com/linux/ubuntu/gpg> | sudo apt-key add -
add-apt-repository "deb [arch=amd64] <https://download.docker.com/linux/ubuntu> focal stable"
apt update
apt upgrade -y
apt install docker-ce -y
curl -L <https://github.com/docker/compose/releases/download/2.15.1/docker-compose-`uname> -s`-`uname -m` -o /usr/local/bin/docker-compose
chmod +x /usr/local/bin/docker-compose
Регистрируете домен в зоне RU для удобства пользования n8n. Домен будет создан чисто под n8n.
После того, как домен зарегистрировали, можете менять там А запись для основного домена и создаете поддомен n8n. IP адрес указываете своего VPS сервера.
У меня это выглядит вот так:
Заходим в папку root и создаем файл docker-compose.yml
Далее в него вставляем код
version: "3"
services:
traefik:
image: "traefik"
restart: always
command:
- "--api=true"
- "--api.insecure=true"
- "--providers.docker=true"
- "--providers.docker.exposedbydefault=false"
- "--entrypoints.websecure.address=:443"
- "--certificatesresolvers.mytlschallenge.acme.tlschallenge=true"
- "--certificatesresolvers.mytlschallenge.acme.email=${SSL_EMAIL}"
- "--certificatesresolvers.mytlschallenge.acme.storage=/letsencrypt/acme.json"
ports:
- "443:443"
volumes:
- ${DATA_FOLDER}/letsencrypt:/letsencrypt
- /var/run/docker.sock:/var/run/docker.sock:ro
n8n:
image: n8nio/n8n
restart: always
ports:
- "127.0.0.1:5678:5678"
labels:
- traefik.enable=true
- traefik.http.routers.n8n.rule=Host(`${SUBDOMAIN}.${DOMAIN_NAME}`)
- traefik.http.routers.n8n.tls=true
- traefik.http.routers.n8n.entrypoints=websecure
- traefik.http.routers.n8n.tls.certresolver=mytlschallenge
- traefik.http.middlewares.n8n.headers.SSLRedirect=true
- traefik.http.middlewares.n8n.headers.STSSeconds=315360000
- traefik.http.middlewares.n8n.headers.browserXSSFilter=true
- traefik.http.middlewares.n8n.headers.contentTypeNosniff=true
- traefik.http.middlewares.n8n.headers.forceSTSHeader=true
- traefik.http.middlewares.n8n.headers.SSLHost=${DOMAIN_NAME}
- traefik.http.middlewares.n8n.headers.STSIncludeSubdomains=true
- traefik.http.middlewares.n8n.headers.STSPreload=true
environment:
- N8N_BASIC_AUTH_ACTIVE=true
- N8N_BASIC_AUTH_USER
- N8N_BASIC_AUTH_PASSWORD
- N8N_HOST=${SUBDOMAIN}.${DOMAIN_NAME}
- N8N_PORT=5678
- N8N_PROTOCOL=https
- NODE_ENV=production
- WEBHOOK_TUNNEL_URL=https://${SUBDOMAIN}.${DOMAIN_NAME}/
- GENERIC_TIMEZONE=${GENERIC_TIMEZONE}
volumes:
- ${DATA_FOLDER}/.n8n:/home/node/.n8n
Там же создаем файл .env и вставляем в него
# папка, где будут лежать ваши сохраненные данные. Можно не менять
DATA_FOLDER=/root/n8n/
# высший домен - надо заменить на ваш домен
DOMAIN_NAME=example.com
# поддомен для n8n. Можно так и оставить, чтобы адрес был n8n.example.com
SUBDOMAIN=n8n
# DOMAIN_NAME and SUBDOMAIN combined decide where n8n will be reachable from
# above example would result in: <https://n8n.example.com>
# ваш логин
N8N_BASIC_AUTH_USER=user
# ваш пароль
N8N_BASIC_AUTH_PASSWORD=password
# Замените на ваш часовой пояс для работ по расписанию. Для Москвы это Europe/Moscow
# Список можно посмотреть здесь: <https://docs.trifacta.com/display/DP/Supported+Time+Zone+Values>
# Если не установлено, будет Нью-Йорк
GENERIC_TIMEZONE=Europe/Berlin
# Почтовый адрес для создания SSL-сертификата - пропишите свой контактный емейл
SSL_EMAIL=user@example.com
У меня он выглядит вот так:
# Folder where data should be saved
DATA_FOLDER=/root/n8n/
# The top level domain to serve from
DOMAIN_NAME=vending-nv.ru
# The subdomain to serve from
SUBDOMAIN=n8n
# DOMAIN_NAME and SUBDOMAIN combined decide where n8n will be reachable from
# above example would result in: https://n8n.example.com
# Optional timezone to set which gets used by Cron-Node by default
# If not set New York time will be used
GENERIC_TIMEZONE=Europe/Berlin
# The email address to use for the SSL certificate creation
SSL_EMAIL=kirill.vech@gmail.com
Создаем новую папку с именем n8n в директории root.
В нее будут сохраняться ваши данные.
docker compose up -d
Ошибка 404 или Bad Getaway появляется на момент FAQ 18.08.2022, возможно её уже починили разработчики
Останавливаете программу
sudo docker stop
Прописываете
docker run --rm -it --user root -v /root/n8n/.n8n:/home/node/.n8n --entrypoint chown n8nio/base:16 -R node:node /home/node/.n8n
И далее снова запускаем и ошибка должна пропасть
docker compose up -d
Полезное
Портфолио