add init-data and change n8n from bind-mount to volume

This commit is contained in:
Kevin Heyer 2025-03-18 18:59:57 +00:00
parent c6831f0aa7
commit 63728e51fe
2 changed files with 23 additions and 7 deletions

View file

@ -7,11 +7,11 @@ services:
- n8n - n8n
restart: always restart: always
environment: environment:
- POSTGRES_USER - POSTGRES_USER=${N8N_POSTGRES_USER}
- POSTGRES_PASSWORD - POSTGRES_PASSWORD=${N8N_POSTGRES_PASSWORD}
- POSTGRES_DB - POSTGRES_DB=${N8N_POSTGRES_DB}
- POSTGRES_NON_ROOT_USER - POSTGRES_NON_ROOT_USER=${N8N_POSTGRES_NON_ROOT_USER}
- POSTGRES_NON_ROOT_PASSWORD - POSTGRES_NON_ROOT_PASSWORD=${N8N_POSTGRES_NON_ROOT_PASSWORD}
volumes: volumes:
- ./data/db:/var/lib/postgresql/data - ./data/db:/var/lib/postgresql/data
- ./init-data.sh:/docker-entrypoint-initdb.d/init-data.sh - ./init-data.sh:/docker-entrypoint-initdb.d/init-data.sh
@ -46,7 +46,7 @@ services:
links: links:
- postgres - postgres
volumes: volumes:
- ./data/n8n:/home/node/.n8n - data:/home/node/.n8n
labels: labels:
- "traefik.enable=true" - "traefik.enable=true"
- "traefik.docker.network=traefik" - "traefik.docker.network=traefik"
@ -68,4 +68,7 @@ networks:
traefik: traefik:
external: true external: true
n8n: n8n:
driver: bridge driver: bridge
volumes:
data:

13
n8n/init-data.sh Normal file
View file

@ -0,0 +1,13 @@
#!/bin/bash
set -e;
if [ -n "${POSTGRES_NON_ROOT_USER:-}" ] && [ -n "${POSTGRES_NON_ROOT_PASSWORD:-}" ]; then
psql -v ON_ERROR_STOP=1 --username "$POSTGRES_USER" --dbname "$POSTGRES_DB" <<-EOSQL
CREATE USER ${POSTGRES_NON_ROOT_USER} WITH PASSWORD '${POSTGRES_NON_ROOT_PASSWORD}';
GRANT ALL PRIVILEGES ON DATABASE ${POSTGRES_DB} TO ${POSTGRES_NON_ROOT_USER};
GRANT CREATE ON SCHEMA public TO ${POSTGRES_NON_ROOT_USER};
EOSQL
else
echo "SETUP INFO: No Environment variables given!"
fi