n8n+postgres+redis docker-compose 예제
안녕하세요. 달소입니다.
앞서 n8n 의 간단한 도커 설치방법을 공유해드렸는데요.
해당 설치방법의 경우 sqlite의 db를 파일로 저장하기때문에 조금 더 성능적인 이점을 원하신다면 이 버전으로 설치하시면 되겠습니다.
설치환경
Ubuntu 22.04
docker / docker-compose
mkdir -p /data/n8n
cd /data/n8n
볼륨은 도커볼륨을 사용합니다.
.env 설정하기
env파일에는 DB정보를 적어주시면됩니다.
vi .env
POSTGRES_PASSWORD=changePassword
POSTGRES_DB=n8n
POSTGRES_NON_ROOT_USER=changeUser
POSTGRES_NON_ROOT_PASSWORD=changePassword
그리고 postgres 최초 생성시 참조할 쉘스크립트 파일도 만듭니다.
vi init-data.sh
#!/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};
EOSQL
else
echo "SETUP INFO: No Environment variables given!"
fi
이제 docker-compose.yml 입니다.
version: '3.8'
volumes:
db_storage:
n8n_storage:
redis_storage:
x-shared: &shared
restart: always
image: docker.n8n.io/n8nio/n8n
environment:
- DB_TYPE=postgresdb
- DB_POSTGRESDB_HOST=postgres
- DB_POSTGRESDB_PORT=5432
- DB_POSTGRESDB_DATABASE=${POSTGRES_DB}
- DB_POSTGRESDB_USER=${POSTGRES_NON_ROOT_USER}
- DB_POSTGRESDB_PASSWORD=${POSTGRES_NON_ROOT_PASSWORD}
- EXECUTIONS_MODE=queue
- QUEUE_BULL_REDIS_HOST=redis
- QUEUE_HEALTH_CHECK_ACTIVE=true
links:
- postgres
- redis
volumes:
- n8n_storage:/home/node/.n8n
depends_on:
redis:
condition: service_healthy
postgres:
condition: service_healthy
services:
postgres:
image: postgres:15
restart: always
environment:
- POSTGRES_USER
- POSTGRES_PASSWORD
- POSTGRES_DB
- POSTGRES_NON_ROOT_USER
- POSTGRES_NON_ROOT_PASSWORD
- N8N_HOST=192.168.1.18
- NODE_FUNCTION_ALLOW_BUILTIN=*
- NODE_FUNCTION_ALLOW_EXTERNAL=moment,lodash
- GENERIC_TIMEZONE=Asia/Seoul
volumes:
- db_storage:/var/lib/postgresql/data
- ./init-data.sh:/docker-entrypoint-initdb.d/init-data.sh
healthcheck:
test: ['CMD-SHELL', 'pg_isready -h localhost -U ${POSTGRES_USER} -d ${POSTGRES_DB}']
interval: 5s
timeout: 5s
retries: 10
redis:
image: redis:7-alpine
restart: always
volumes:
- redis_storage:/data
healthcheck:
test: ['CMD', 'redis-cli', 'ping']
interval: 5s
timeout: 5s
retries: 10
n8n:
<<: *shared
ports:
- 5678:5678
n8n-worker:
<<: *shared
command: worker
depends_on:
- n8n
최종적으로는 아래와같은 파일들이 위치해있으면 됩니다.
그리고 docker-compose up -d
컨테이너가 모두 올라오면 ip:5678 포트로 접속해주시면됩니다.
더 많은 환경변수들은 아래 링크를 참고해주세요.
EACCES: permission denied, open '/home/node/.n8n/config' 라고 나오는데 권한 문제가 있는듯 합니다,
깃헙보니 데비안 계열에 권한 문제가 있다는데 해결 방법 없을까요?
https://github.com/n8n-io/n8n/issues/1240
로컬 볼륨쪽에 chown -R 1000:1000 /volume1/docker/n8n 권한 주니 해결됐습니다....
그런데요... 요건 넘어가긴 했는데 postgre db와 통신하고 초기 사용자 등록 및 db 설정하는 곳에서 또 permission 문제가 나오네용 TT 산넘어 산이네요...
초기 접속 후 please wait 만 나오고 안넘어가서 로그 보니 이번엔 db 쪽 권한 문제입니다....
n8n 커뮤니티 보니 관련 이슈가 있긴한데 명확한 답이 없어 찾아보고 있습니다....
혹 시놀로지에서 위 yaml 성공하신분 계시나요????
cmt alert