Official docker images are published on docker hub for AMD64, ARMv7 and ARM64/v8: https://hub.docker.com/r/triliumnext/notes/
Ensure Docker is installed on your system.
If you need help installing Docker, reference the Docker Installation Docs
Note: Trilium’s Docker container requires root privileges to operate correctly.
[!WARNING] If you’re using a SMB/CIFS share or folder as your Trilium data directory, you’ll need to add the mount options of
nobrl
andnoperm
when mounting your SMB share.
To pull the image, use the following command, replacing [VERSION]
with the desired version or tag, such as 0.90-latest
or just latest
:
docker pull triliumnext/notes:[VERSION]
Warning: Avoid using the “latest” tag, as it may automatically upgrade your instance to a new minor version, potentially disrupting sync setups or causing other issues.
Trilium requires a directory on the host system to store its data. This directory must be mounted into the Docker container with write permissions.
Run the container to make it accessible only from the localhost. This setup is suitable for testing or when using a proxy server like Nginx or Apache.
sudo docker run -t -i -p 127.0.0.1:8080:8080 -v ~/trilium-data:/home/node/trilium-data triliumnext/notes:[VERSION]
docker ps
.127.0.0.1:8080
.To make the container accessible only on your local network, first create a new Docker network:
docker network create -d macvlan -o parent=eth0 --subnet 192.168.2.0/24 --gateway 192.168.2.254 --ip-range 192.168.2.252/27 mynet
Then, run the container with the network settings:
docker run --net=mynet -d -p 127.0.0.1:8080:8080 -v ~/trilium-data:/home/node/trilium-data triliumnext/notes:<VERSION>-latest
To set a different user ID (UID) and group ID (GID) for the saved data, use the USER_UID
and USER_GID
environment variables:
docker run --net=mynet -d -p 127.0.0.1:8080:8080 -e "USER_UID=1001" -e "USER_GID=1001" -v ~/trilium-data:/home/node/trilium-data triliumnext/notes:<VERSION>-latest
Find the local IP address using docker inspect [container_name]
and access the service from devices on the local network.
docker ps
docker inspect [container_name]
To allow access from any IP address, run the container as follows:
docker run -d -p 0.0.0.0:8080:8080 -v ~/trilium-data:/home/node/trilium-data triliumnext/notes:[VERSION]
Stop the container with docker stop <CONTAINER ID>
, where the container ID is obtained from docker ps
.
For a custom data directory, use:
-v ~/YourOwnDirectory:/home/node/trilium-data triliumnext/notes:[VERSION]
If you want to run your instance in a non-default way, please use the volume switch as follows: -v ~/YourOwnDirectory:/home/node/trilium-data triliumnext/notes:<VERSION>
. It is important to be aware of how Docker works for volumes, with the first path being your own and the second the one to virtually bind to. https://docs.docker.com/storage/volumes/
The path before the colon is the host directory, and the path after the colon is the container’s path. More details can be found in the Docker Volumes Documentation.
The --user
directive is unsupported. Instead, use the USER_UID
and USER_GID
environment variables to set the appropriate user and group IDs.
If you are having timezone issues and you are not using docker-compose, you may need to add a TZ
environment variable with the TZ identifier of your local timezone.