N8N DockerInstall

Overview

While investigating on AI technologies, I found out several usefull use cases I wanted to try. Most of them required cloud related technologies, to automate workflow, and I have started looking for solutions I could host in my home Lab for free. One of the solution I have found out is N8N.

What is n8n

n8n is a powerful workflow automation platform that allows users to create custom automations using a visual interface or custom code. It offers a fair-code distribution model, which means that the source code is always visible, and users can self-host, extend, and customize the platform to suit their needs.

Sample Workflow

Key Features:

  • 400+ integrations with various services and tools
  • Native AI capabilities
  • Visual building and custom code options
  • Self-hosting and cloud hosting options
  • Fair-code license for full control over data and deployments n8n is designed to provide flexibility and speed, making it a popular choice for technical teams and developers.

After trying it on a sandbox, I decided to deploy it in my homelab. It is pretty reactive, and the interface is very smooth.

Docker integration

One requirement for my homelab is to host only tools in docker containers, using single or multiple containers. After some struggle, here is the docker-compose file I used :

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
version: '3'
volumes:
  n8n_db_storage:
  n8n_storage:
  
services:
  n8n:
    image: n8nio/n8n:latest
    ports:
      - "5678:5678"
    environment:
      - DB_TYPE=postgresdb
      - DB_POSTGRESDB_HOST=db
      - DB_POSTGRESDB_PORT=5432
      - DB_POSTGRESDB_DATABASE=n8n
      - DB_POSTGRESDB_USER=n8nuser
      - DB_POSTGRESDB_PASSWORD=n8npwd
      - GENERIC_TIMEZONE=Europe/Zurich
      - TZ=Europe/Zurich
      - WEBHOOK_URL=https://n8n.mydomain.com
    volumes:
      - n8n_storage:/home/node/.n8n
    user: "1000:1000"
    depends_on:
      - db
  db:
    image: postgres:13
    environment:
      - POSTGRES_USER=n8nuser
      - POSTGRES_PASSWORD=n8npwd
      - POSTGRES_DB=n8n
    volumes:
      - n8n_db_storage:/var/lib/postgresql/data

This can be used as a custom Template in Portainer. Update username and pwd at your convenience.

Password Reset

Trying to connect from another computer, I realized the password was no longer working, I had to found out a way to reset it. Reseting password is possible through CLI commands. You can use CLI commands with self-hosted n8n. Depending on how you choose to install n8n, there are differences in how to run the commands. For Docker the n8n command is available within your Docker container:

1
    docker exec -u node -it <n8n-container-name> n8n user-management:reset

You can reset user management using the n8n CLI. This returns user management to its pre-setup state. It removes all user accounts. Use this if you forget your password, and don’t have SMTP set up to do password resets by email.

Chat entry point

There are some ressources available to create a gpt like chat windows which can be used as trigger for the n8n workflows : n8n chat windows .

References