Hosting n8n on DigitalOcean#
This hosting guide shows you how to self-host n8n on a DigitalOcean droplet. It uses:
- Caddy (a reverse proxy) to allow access to the Droplet from the internet. Caddy will also automatically create and manage SSL / TLS certificates for your n8n instance.
- Docker Compose to create and define the application components and how they work together.
Self-hosting knowledge prerequisites
Self-hosting n8n requires technical knowledge, including:
- Setting up and configuring servers and containers
- Managing application resources and scaling
- Securing servers and applications
- Configuring n8n
n8n recommends self-hosting for expert users. Mistakes can lead to data loss, security issues, and downtime. If you aren't experienced at managing servers, n8n recommends n8n Cloud.
Latest and Next versions
n8n releases a new minor version most weeks. The latest
version is for production use. next
is the most recent release. You should treat next
as a beta: it may be unstable. To report issues, use the forum.
Current latest
: 1.72.1
Current next
: 1.73.1
Create a Droplet#
- Log in to DigitalOcean.
- Select the project to host the Droplet, or create a new project.
- In your project, select Droplets from the Manage menu.
- Create a new Droplet using the Docker image available on the Marketplace tab.
Droplet resources
When creating the Droplet, DigitalOcean asks you to choose a plan. For most usage levels, a basic shared CPU plan is enough.
SSH key or Password
DigitalOcean lets you choose between SSH key and password-based authentication. SSH keys are considered more secure.
Log in to your Droplet and create new user#
The rest of this guide requires you to log in to the Droplet using a terminal with SSH. Refer to How to Connect to Droplets with SSH for more information.
You should create a new user, to avoid working as the root user:
- Log in as root.
- Create a new user:
1
adduser <username>
- Follow the prompts in the CLI to finish creating the user.
- Grant the new user administrative privileges:
You can now run commands with superuser privileges by using
1
usermod -aG sudo <username>
sudo
before the command. - Follow the steps to set up SSH for the new user: Add Public Key Authentication.
- Log out of the droplet.
- Log in using SSH as the new user.
Clone configuration repository#
Docker Compose, n8n, and Caddy require a series of folders and configuration files. You can clone these from this repository into the home folder of the logged-in user on your Droplet. The following steps will tell you which file to change and what changes to make.
Clone the repository with the following command:
1 |
|
And change directory to the root of the repository you cloned:
1 |
|
Default folders and files#
The host operating system (the DigitalOcean Droplet) copies the two folders you created to Docker containers to make them available to Docker. The two folders are:
caddy_config
: Holds the Caddy configuration files.local_files
: A folder for files you upload or add using n8n.
Create Docker volumes#
To persist the Caddy cache between restarts and speed up start times, create a Docker volume that Docker reuses between restarts:
1 |
|
Create a Docker volume for the n8n data:
1 |
|
Set up DNS#
n8n typically operates on a subdomain. Create a DNS record with your provider for the subdomain and point it to the IP address of the Droplet. The exact steps for this depend on your DNS provider, but typically you need to create a new "A" record for the n8n subdomain. DigitalOcean provide An Introduction to DNS Terminology, Components, and Concepts.
Open ports#
n8n runs as a web application, so the Droplet needs to allow incoming access to traffic on port 80 for non-secure traffic, and port 443 for secure traffic.
Open the following ports in the Droplet's firewall by running the following two commands:
1 2 |
|
Configure n8n#
n8n needs some environment variables set to pass to the application running in the Docker container. The example .env
file contains placeholders you need to replace with values of your own.
Open the file with the following command:
1 |
|
The file contains inline comments to help you know what to change.
Refer to Environment variables for n8n environment variables details.
The Docker Compose file#
The Docker Compose file (docker-compose.yml
) defines the services the application needs, in this case Caddy and n8n.
- The Caddy service definition defines the ports it uses and the local volumes to copy to the containers.
- The n8n service definition defines the ports it uses, the environment variables n8n needs to run (some defined in the
.env
file), and the volumes it needs to copy to the containers.
The Docker Compose file uses the environment variables set in the .env
file, so you shouldn't need to change it's content, but to take a look, run the following command:
1 |
|
Configure Caddy#
Caddy needs to know which domains it should serve, and which port to expose to the outside world. Edit the Caddyfile
file in the caddy_config
folder.
1 |
|
Change the placeholder domain to yours. If you followed the steps to name the subdomain n8n, your full domain is similar to n8n.example.com
. The n8n
in the reverse_proxy
setting tells Caddy to use the service definition defined in the docker-compose.yml
file:
1 2 3 4 5 |
|
If you were to use automate.example.com
, your Caddyfile
may look something like:
1 2 3 4 5 |
|
Start Docker Compose#
Start n8n and Caddy with the following command:
1 |
|
This may take a few minutes.
Test your setup#
In your browser, open the URL formed of the subdomain and domain name defined earlier. Enter the user name and password defined earlier, and you should be able to access n8n.
Stop n8n and Caddy#
You can stop n8n and Caddy with the following command:
1 |
|
Updating#
If you run n8n using a Docker Compose file, follow these steps to update n8n:
1 2 3 4 5 6 7 8 |
|
Next steps#
- Learn more about configuring and scaling n8n.
- Or explore using n8n: try the Quickstarts.