Automatize Tudo com N8N! Instalação Rápida e Poderosa

Automatize Tudo com N8N!  Instalação Rápida e Poderosa

Neste tutorial, você aprenderá:

✔️ Como instalar o N8N de forma simples e rápida utilizando Docker.
✔️ Como configurar um domínio para acessar seu aplicativo de maneira segura com SSL.

📌 Facilite seu processo de deploy com o nosso painel ICP!

  1. Criando o Arquivo Docker Compose

Para instalar o N8N corretamente, seguiremos as diretrizes do manual oficial.

🔗 Documentação oficial do N8N:
https://docs.n8n.io/hosting/installation/docker/

  1. Agora, vamos criar o arquivo docker-compose.yml com a configuração necessária para rodar o N8N em um ambiente Docker.
version: "3.7"

services:
  traefik:
    image: "traefik"
    restart: always
    command:
      - "--api=true"
      - "--api.insecure=true"
      - "--providers.docker=true"
      - "--providers.docker.exposedbydefault=false"
      - "--entrypoints.web.address=:80"
      - "--entrypoints.web.http.redirections.entryPoint.to=websecure"
      - "--entrypoints.web.http.redirections.entrypoint.scheme=https"
      - "--entrypoints.websecure.address=:443"
      - "--certificatesresolvers.mytlschallenge.acme.tlschallenge=true"
      - "--certificatesresolvers.mytlschallenge.acme.email=${SSL_EMAIL}"
      - "--certificatesresolvers.mytlschallenge.acme.storage=/letsencrypt/acme.json"
    ports:
      - "801:80"
      - "4431:443"
    volumes:
      - /home/n8n/traefik_data:/letsencrypt
      - /var/run/docker.sock:/var/run/docker.sock:ro

  n8n:
    image: docker.n8n.io/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=web,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
      - traefik.http.routers.n8n.middlewares=n8n@docker
    environment:
      - N8N_HOST=${SUBDOMAIN}.${DOMAIN_NAME}
      - N8N_PORT=5678
      - N8N_PROTOCOL=https
      - NODE_ENV=production
      - WEBHOOK_URL=https://${SUBDOMAIN}.${DOMAIN_NAME}/
      - GENERIC_TIMEZONE=${GENERIC_TIMEZONE}
    volumes:
      - /home/n8n/n8n_data:/home/node/.n8n

volumes:
  traefik_data:
    external: true
  n8n_data:
    external: true

  1. Precisamos criar o novo arquivo .env
# The top level domain to serve from
DOMAIN_NAME=icp.icontainer.run

# 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=America/Sao_Paulo
# The email address to use for the SSL certificate creation
SSL_EMAIL=suporte@integrator.com.br


Pronto, com isso temos uma ambiente para rodar o nosso N8N.
Agora para que possamos testar e subir o nosso docker, vamos usar o painel ICP da Integrator Host, ele permite ter o N8N em um domínio com SSL, veja como funciona no video abaixo.

Veja também o exemplo em video e como publicar em um domínio com ssl usando o nosso painel ICP