80 lines
2.7 KiB
YAML
80 lines
2.7 KiB
YAML
version: "2.1"
|
|
|
|
services:
|
|
nocodb:
|
|
container_name: nocodb
|
|
depends_on:
|
|
nocodb-db:
|
|
condition: service_healthy
|
|
environment:
|
|
- NC_DB=pg://nocodb-db:5432?u=postgres&p=${NOCODB_DB_PASSWORD}&d=nocodb
|
|
- NC_PUBLIC_URL=${APP_PROTOCOL:-http}://${APP_DOMAIN}
|
|
- NC_AUTH_JWT_SECRET=${NOCODB_JWT_SECRET}
|
|
- NC_REDIS_URL=redis://default:${NOCODB_REDIS_PASSWORD}@nocodb-redis:6379
|
|
image: "nocodb/nocodb:0.111.1"
|
|
ports:
|
|
- "${APP_PORT}:8080"
|
|
restart: always
|
|
volumes:
|
|
- "${APP_DATA_DIR}/data/nocode-data:/usr/app/data"
|
|
networks:
|
|
- tipi_main_network
|
|
labels:
|
|
# Main
|
|
traefik.enable: true
|
|
traefik.http.middlewares.nocodb-web-redirect.redirectscheme.scheme: https
|
|
traefik.http.services.nocodb.loadbalancer.server.port: 8080
|
|
# Web
|
|
traefik.http.routers.nocodb-insecure.rule: Host(`${APP_DOMAIN}`)
|
|
traefik.http.routers.nocodb-insecure.entrypoints: web
|
|
traefik.http.routers.nocodb-insecure.service: nocodb
|
|
traefik.http.routers.nocodb-insecure.middlewares: nocodb-web-redirect
|
|
# Websecure
|
|
traefik.http.routers.nocodb.rule: Host(`${APP_DOMAIN}`)
|
|
traefik.http.routers.nocodb.entrypoints: websecure
|
|
traefik.http.routers.nocodb.service: nocodb
|
|
traefik.http.routers.nocodb.tls.certresolver: myresolver
|
|
# Local domain
|
|
traefik.http.routers.nocodb-local-insecure.rule: Host(`nocodb.${LOCAL_DOMAIN}`)
|
|
traefik.http.routers.nocodb-local-insecure.entrypoints: web
|
|
traefik.http.routers.nocodb-local-insecure.service: nocodb
|
|
traefik.http.routers.nocodb-local-insecure.middlewares: nocodb-web-redirect
|
|
# Local domain secure
|
|
traefik.http.routers.nocodb-local.rule: Host(`nocodb.${LOCAL_DOMAIN}`)
|
|
traefik.http.routers.nocodb-local.entrypoints: websecure
|
|
traefik.http.routers.nocodb-local.service: nocodb
|
|
traefik.http.routers.nocodb-local.tls: true
|
|
|
|
nocodb-db:
|
|
container_name: nocodb-db
|
|
environment:
|
|
POSTGRES_DB: nocodb
|
|
POSTGRES_PASSWORD: ${NOCODB_DB_PASSWORD}
|
|
POSTGRES_USER: postgres
|
|
healthcheck:
|
|
interval: 10s
|
|
retries: 10
|
|
test: 'pg_isready -U "$$POSTGRES_USER" -d "$$POSTGRES_DB"'
|
|
timeout: 2s
|
|
image: postgres
|
|
restart: always
|
|
volumes:
|
|
- ${APP_DATA_DIR}/data/postgres:/var/lib/postgresql/data
|
|
networks:
|
|
- tipi_main_network
|
|
|
|
nocodb-redis:
|
|
image: redis:alpine
|
|
container_name: nocodb-redis
|
|
restart: unless-stopped
|
|
command: "redis-server --requirepass ${NOCODB_REDIS_PASSWORD}"
|
|
volumes:
|
|
- ${APP_DATA_DIR}/data/redis:/data
|
|
healthcheck:
|
|
test: ["CMD", "redis-cli", "ping"]
|
|
interval: 1s
|
|
timeout: 3s
|
|
retries: 30
|
|
networks:
|
|
- tipi_main_network
|