Compare commits

...

11 Commits

Author SHA1 Message Date
3wordchant da168a62cc Merge pull request 'default_sqlite' (#4) from default_sqlite into main
continuous-integration/drone/push Build is passing Details
Reviewed-on: #4
2024-04-11 21:01:44 +00:00
Cassowary d450ef32f0 Add release notes 2024-04-11 13:48:15 -07:00
Cassowary daa00ec73c Fix version in compose.postgres.yml 2024-04-09 09:40:40 -07:00
Cassowary 7f5744f02e Remove stray swp file 2024-04-09 09:32:28 -07:00
Cassowary da957caf81 Split postgres support into separate compose so that it defaults to sqlite instead 2024-04-09 09:31:12 -07:00
3wc db29a2ec3c chore: publish 0.7.0+0.237.0 release
continuous-integration/drone/push Build is failing Details
2024-01-20 21:40:59 -03:00
3wc e1e9a05be3 Add postgres upgrade magic 2024-01-20 21:40:15 -03:00
3wc a9bb848aba chore: publish 0.6.2+0.236.3 release
continuous-integration/drone/push Build is passing Details
2023-07-25 15:47:15 +01:00
3wc 30d9f2976e Don't specify image in compose.sso..
..otherwise it sneakily upgrades us to n8n:latest which is Not Good
2023-07-25 15:46:41 +01:00
3wc f4f7f6d720 chore: publish 0.6.1+0.236.3 release
continuous-integration/drone/push Build is passing Details
2023-07-24 14:24:15 +01:00
3wc 89e09081cf chore: publish 0.6.0+0.236.0 release
continuous-integration/drone/push Build is passing Details
2023-07-08 19:46:02 +01:00
8 changed files with 120 additions and 46 deletions

View File

@ -6,8 +6,6 @@ DOMAIN=n8n.example.com
#EXTRA_DOMAINS=', `www.n8n.example.com`'
LETS_ENCRYPT_ENV=production
SECRET_DB_PASSWORD_VERSION=v1
# Change to `true` to enable sending "anonymous" telemetry data to n8n
# https://docs.n8n.io/reference/data-collection/
N8N_DIAGNOSTICS_ENABLED=false
@ -31,3 +29,7 @@ COMPOSE_FILE="compose.yml"
#N8N_BASIC_AUTH_ACTIVE=true
#N8N_BASIC_AUTH_USER=username
#SECRET_ADMIN_PASSWORD_VERSION=v1
# Use Postgres instead of SQLite
#COMPOSE_FILE="$COMPOSE_FILE:compose.postgres.yml"
#SECRET_DB_PASSWORD_VERSION=v1

Binary file not shown.

1
abra.sh Normal file
View File

@ -0,0 +1 @@
export DB_ENTRYPOINT_VERSION=v1

60
compose.postgres.yml Normal file
View File

@ -0,0 +1,60 @@
---
version: '3.8'
# Compose for PostGres mode instead of the default sqlite mode.
services:
app:
environment:
- DB_TYPE=postgresdb
- DB_POSTGRESDB_HOST=${STACK_NAME}_db
- DB_POSTGRESDB_PORT=5432
- DB_POSTGRESDB_DATABASE=n8n
- DB_POSTGRESDB_USER=root
- DB_POSTGRESDB_PASSWORD_FILE=/run/secrets/db_password
depends_on:
- db
secrets:
- db_password
db:
image: postgres:16
networks:
- internal_network
environment:
- POSTGRES_USER=root
- POSTGRES_PASSWORD_FILE=/run/secrets/db_password
- POSTGRES_DB=n8n
configs:
- source: db_entrypoint
target: /docker-entrypoint.sh
mode: 0555
secrets:
- db_password
healthcheck:
test: ["CMD", "pg_isready", "-U", "root", "-d", "n8n"]
volumes:
- 'postgresql_data:/var/lib/postgresql/data'
entrypoint: /docker-entrypoint.sh
deploy:
labels:
backupbot.backup: "true"
backupbot.backup.pre-hook: "bash -c 'PGPASSWORD=$$(cat $${POSTGRES_PASSWORD_FILE}) pg_dump -U $${POSTGRES_USER} $${POSTGRES_DB} > /tmp/backup.sql'"
backupbot.backup.post-hook: "rm -rf /tmp/backup.sql"
backupbot.backup.path: "/tmp/backup.sql"
secrets:
# db_non_root_password:
# external: true
# name: ${STACK_NAME}_db_non_root_password_${SECRET_DB_NON_ROOT_PASSWORD_VERSION}
db_password:
external: true
name: ${STACK_NAME}_db_password_${SECRET_DB_PASSWORD_VERSION}
volumes:
postgresql_data:
configs:
db_entrypoint:
name: ${STACK_NAME}_db_entrypoint_${DB_ENTRYPOINT_VERSION}
file: entrypoint.postgres.sh.tmpl
template_driver: golang

View File

@ -4,7 +4,6 @@ version: '3.8'
services:
app:
image: n8nio/n8n
environment:
- N8N_BASIC_AUTH_ACTIVE=false
deploy:

View File

@ -3,29 +3,19 @@ version: '3.8'
services:
app:
image: n8nio/n8n:0.226.0
image: n8nio/n8n:0.237.0
environment:
- DB_TYPE=postgresdb
- DB_POSTGRESDB_HOST=${STACK_NAME}_db
- DB_POSTGRESDB_PORT=5432
- DB_POSTGRESDB_DATABASE=n8n
- DB_POSTGRESDB_USER=root
- DB_POSTGRESDB_PASSWORD_FILE=/run/secrets/db_password
- N8N_PERSONALIZATION_ENABLED
- N8N_DIAGNOSTICS_ENABLED
- N8N_USER_MANAGEMENT_DISABLED
- N8N_BASIC_AUTH_ACTIVE=false
- WEBHOOK_URL=https://${DOMAIN}
- NODE_FUNCTION_ALLOW_EXTERNAL=moment
depends_on:
- db
networks:
- proxy
- internal_network
volumes:
- n8n:/home/node/.n8n
secrets:
- db_password
deploy:
update_config:
failure_action: rollback
@ -40,43 +30,12 @@ services:
- "traefik.http.routers.${STACK_NAME}.middlewares=${STACK_NAME}-redirect"
- "traefik.http.middlewares.${STACK_NAME}-redirect.headers.SSLForceHost=true"
- "traefik.http.middlewares.${STACK_NAME}-redirect.headers.SSLHost=${DOMAIN}"
- "coop-cloud.${STACK_NAME}.version=0.5.0+0.226.0"
- "coop-cloud.${STACK_NAME}.version=0.7.0+0.237.0"
- "backupbot.backup=true"
- "backupbot.backup.path=/home/node/.n8n"
db:
image: postgres:11
networks:
- internal_network
environment:
- POSTGRES_USER=root
- POSTGRES_PASSWORD_FILE=/run/secrets/db_password
- POSTGRES_DB=n8n
secrets:
- db_password
healthcheck:
test: ["CMD", "pg_isready", "-U", "root", "-d", "n8n"]
volumes:
- 'postgresql_data:/var/lib/postgresql/data'
# - ./init-data.sh:/docker-entrypoint-initdb.d/init-data.sh
deploy:
labels:
backupbot.backup: "true"
backupbot.backup.pre-hook: "bash -c 'PGPASSWORD=$$(cat $${POSTGRES_PASSWORD_FILE}) pg_dump -U $${POSTGRES_USER} $${POSTGRES_DB} > /tmp/backup.sql'"
backupbot.backup.post-hook: "rm -rf /tmp/backup.sql"
backupbot.backup.path: "/tmp/backup.sql"
secrets:
# db_non_root_password:
# external: true
# name: ${STACK_NAME}_db_non_root_password_${SECRET_DB_NON_ROOT_PASSWORD_VERSION}
db_password:
external: true
name: ${STACK_NAME}_db_password_${SECRET_DB_PASSWORD_VERSION}
volumes:
n8n:
postgresql_data:
networks:
proxy:

View File

@ -0,0 +1,44 @@
#!/bin/bash
set -e
MIGRATION_MARKER=$PGDATA/migration_in_progress
OLDDATA=$PGDATA/old_data
NEWDATA=$PGDATA/new_data
if [ -e $MIGRATION_MARKER ]; then
echo "FATAL: migration was started but did not complete in a previous run. manual recovery necessary"
exit 1
fi
if [ -f $PGDATA/PG_VERSION ]; then
DATA_VERSION=$(cat $PGDATA/PG_VERSION)
if [ -n "$DATA_VERSION" -a "$PG_MAJOR" != "$DATA_VERSION" ]; then
echo "postgres data version $DATA_VERSION found, but need $PG_MAJOR. Starting migration"
echo "Installing postgres $DATA_VERSION"
sed -i "s/$/ $DATA_VERSION/" /etc/apt/sources.list.d/pgdg.list
apt-get update && apt-get install -y --no-install-recommends \
postgresql-$DATA_VERSION \
&& rm -rf /var/lib/apt/lists/*
echo "shuffling around"
gosu postgres mkdir $OLDDATA $NEWDATA
chmod 700 $OLDDATA $NEWDATA
mv $PGDATA/* $OLDDATA/ || true
touch $MIGRATION_MARKER
echo "running initdb"
# abuse entrypoint script for initdb by making server error out
gosu postgres bash -c "export PGDATA=$NEWDATA ; /usr/local/bin/docker-entrypoint.sh --invalid-arg || true"
echo "running pg_upgrade"
cd /tmp
gosu postgres pg_upgrade --link -b /usr/lib/postgresql/$DATA_VERSION/bin -d $OLDDATA -D $NEWDATA -U $POSTGRES_USER
cp $OLDDATA/pg_hba.conf $NEWDATA/
mv $NEWDATA/* $PGDATA
rm -rf $OLDDATA
rmdir $NEWDATA
rm $MIGRATION_MARKER
echo "migration complete"
fi
fi
/usr/local/bin/docker-entrypoint.sh postgres

9
release/next Normal file
View File

@ -0,0 +1,9 @@
ALERTA ALERTA
N8N recipe is switching from deploying a PostgreSQL and setting it as the database to using the
built-in SQLite database instead. PostgreSQL can still be enabled, see .env.sample for the
lines to add to your configuration to enable it (should retain data that was in Postgres).
There is no clean migration path between sqlite and postgres. Committing to one pretty much
sticks you to that one (there are hacks but it is involved and incomplete).