Compare commits
2 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| cb241c9696 | |||
| 4b99e21a99 |
@@ -13,7 +13,7 @@ Each stack is independently deployable with its own `compose.yml` and `.env`. Al
|
|||||||
| `watchtower` | Automatic container updates | watchtower |
|
| `watchtower` | Automatic container updates | watchtower |
|
||||||
| `umami` | Web analytics | umami, db |
|
| `umami` | Web analytics | umami, db |
|
||||||
| `immich` | Photo & video management | immich, ml, redis, db |
|
| `immich` | Photo & video management | immich, ml, redis, db |
|
||||||
| `blinko` | AI-powered personal notes | blinko, db |
|
| `affine` | Collaborative workspace & notes | affine, redis, db |
|
||||||
| `n8n` | Workflow automation & notification relay | n8n, db |
|
| `n8n` | Workflow automation & notification relay | n8n, db |
|
||||||
| `gitea` | Git hosting + CI runner | gitea, runner, db |
|
| `gitea` | Git hosting + CI runner | gitea, runner, db |
|
||||||
| `coolify` | Deployment platform | coolify, realtime, redis, db |
|
| `coolify` | Deployment platform | coolify, realtime, redis, db |
|
||||||
|
|||||||
+1
-1
@@ -33,7 +33,7 @@ mkdir -p "$DUMP_DIR"
|
|||||||
|
|
||||||
declare -A DATABASES=(
|
declare -A DATABASES=(
|
||||||
[umami_db]="umami:umami"
|
[umami_db]="umami:umami"
|
||||||
[blinko_db]="blinko:blinko"
|
[affine_db]="affine:affine"
|
||||||
[gitea_db]="gitea:gitea"
|
[gitea_db]="gitea:gitea"
|
||||||
[n8n_db]="n8n:n8n"
|
[n8n_db]="n8n:n8n"
|
||||||
[immich_db]="immich:immich"
|
[immich_db]="immich:immich"
|
||||||
|
|||||||
@@ -0,0 +1,11 @@
|
|||||||
|
TRAEFIK_HOST=affine.example.com
|
||||||
|
NETWORK_NAME=falcon_network
|
||||||
|
DB_USERNAME=affine
|
||||||
|
DB_PASSWORD=change_me
|
||||||
|
DB_DATABASE=affine
|
||||||
|
MAILER_HOST=mailpit
|
||||||
|
MAILER_PORT=1025
|
||||||
|
MAILER_USER=affine
|
||||||
|
MAILER_PASSWORD=affine
|
||||||
|
MAILER_SENDER=affine@example.com
|
||||||
|
MAILER_IGNORE_TLS=true
|
||||||
@@ -0,0 +1,88 @@
|
|||||||
|
services:
|
||||||
|
affine:
|
||||||
|
image: ghcr.io/toeverything/affine:stable
|
||||||
|
container_name: affine
|
||||||
|
env_file: .env
|
||||||
|
environment:
|
||||||
|
REDIS_SERVER_HOST: redis
|
||||||
|
DATABASE_URL: postgresql://${DB_USERNAME}:${DB_PASSWORD}@postgres:5432/${DB_DATABASE:-affine}
|
||||||
|
AFFINE_SERVER_EXTERNAL_URL: https://${TRAEFIK_HOST}
|
||||||
|
AFFINE_INDEXER_ENABLED: "false"
|
||||||
|
volumes:
|
||||||
|
- ../.data/affine/storage:/root/.affine/storage
|
||||||
|
- ../.data/affine/config:/root/.affine/config
|
||||||
|
depends_on:
|
||||||
|
redis:
|
||||||
|
condition: service_healthy
|
||||||
|
postgres:
|
||||||
|
condition: service_healthy
|
||||||
|
affine_migration:
|
||||||
|
condition: service_completed_successfully
|
||||||
|
restart: unless-stopped
|
||||||
|
labels:
|
||||||
|
- "traefik.enable=true"
|
||||||
|
- "traefik.http.middlewares.affine-redirect-web-secure.redirectscheme.scheme=https"
|
||||||
|
- "traefik.http.routers.affine-web.middlewares=affine-redirect-web-secure"
|
||||||
|
- "traefik.http.routers.affine-web.rule=Host(`${TRAEFIK_HOST}`)"
|
||||||
|
- "traefik.http.routers.affine-web.entrypoints=web"
|
||||||
|
- "traefik.http.routers.affine-web-secure.rule=Host(`${TRAEFIK_HOST}`)"
|
||||||
|
- "traefik.http.routers.affine-web-secure.tls.certresolver=resolver"
|
||||||
|
- "traefik.http.routers.affine-web-secure.entrypoints=web-secure"
|
||||||
|
- "traefik.http.routers.affine-web-secure.middlewares=security-headers@file,no-index@file"
|
||||||
|
- "traefik.http.services.affine-web-secure.loadbalancer.server.port=3010"
|
||||||
|
- "traefik.docker.network=${NETWORK_NAME}"
|
||||||
|
- "com.centurylinklabs.watchtower.enable=true"
|
||||||
|
networks:
|
||||||
|
- compose_network
|
||||||
|
affine_migration:
|
||||||
|
image: ghcr.io/toeverything/affine:stable
|
||||||
|
container_name: affine_migration
|
||||||
|
env_file: .env
|
||||||
|
command: ['sh', '-c', 'node ./scripts/self-host-predeploy.js']
|
||||||
|
environment:
|
||||||
|
REDIS_SERVER_HOST: redis
|
||||||
|
DATABASE_URL: postgresql://${DB_USERNAME}:${DB_PASSWORD}@postgres:5432/${DB_DATABASE:-affine}
|
||||||
|
AFFINE_INDEXER_ENABLED: "false"
|
||||||
|
volumes:
|
||||||
|
- ../.data/affine/storage:/root/.affine/storage
|
||||||
|
- ../.data/affine/config:/root/.affine/config
|
||||||
|
depends_on:
|
||||||
|
postgres:
|
||||||
|
condition: service_healthy
|
||||||
|
redis:
|
||||||
|
condition: service_healthy
|
||||||
|
networks:
|
||||||
|
- compose_network
|
||||||
|
redis:
|
||||||
|
image: redis
|
||||||
|
container_name: affine_redis
|
||||||
|
healthcheck:
|
||||||
|
test: ['CMD', 'redis-cli', '--raw', 'incr', 'ping']
|
||||||
|
interval: 10s
|
||||||
|
timeout: 5s
|
||||||
|
retries: 5
|
||||||
|
restart: unless-stopped
|
||||||
|
networks:
|
||||||
|
- compose_network
|
||||||
|
postgres:
|
||||||
|
image: pgvector/pgvector:pg16
|
||||||
|
container_name: affine_db
|
||||||
|
environment:
|
||||||
|
POSTGRES_USER: ${DB_USERNAME}
|
||||||
|
POSTGRES_PASSWORD: ${DB_PASSWORD}
|
||||||
|
POSTGRES_DB: ${DB_DATABASE:-affine}
|
||||||
|
POSTGRES_INITDB_ARGS: --data-checksums
|
||||||
|
volumes:
|
||||||
|
- ../.data/affine/db:/var/lib/postgresql/data
|
||||||
|
healthcheck:
|
||||||
|
test: ['CMD', 'pg_isready', '-U', "${DB_USERNAME}", '-d', "${DB_DATABASE:-affine}"]
|
||||||
|
interval: 10s
|
||||||
|
timeout: 5s
|
||||||
|
retries: 5
|
||||||
|
restart: unless-stopped
|
||||||
|
networks:
|
||||||
|
- compose_network
|
||||||
|
networks:
|
||||||
|
compose_network:
|
||||||
|
name: ${NETWORK_NAME}
|
||||||
|
external: true
|
||||||
@@ -1,3 +0,0 @@
|
|||||||
NETWORK_NAME=falcon_network
|
|
||||||
TRAEFIK_HOST=blinko.example.com
|
|
||||||
BLINKO_NEXTAUTH_SECRET=change_me
|
|
||||||
@@ -1,53 +0,0 @@
|
|||||||
services:
|
|
||||||
blinko:
|
|
||||||
image: blinkospace/blinko:latest
|
|
||||||
container_name: blinko
|
|
||||||
environment:
|
|
||||||
TZ: ${TIMEZONE:-Europe/Amsterdam}
|
|
||||||
NODE_ENV: production
|
|
||||||
NEXTAUTH_URL: https://${TRAEFIK_HOST}
|
|
||||||
NEXT_PUBLIC_BASE_URL: https://${TRAEFIK_HOST}
|
|
||||||
NEXTAUTH_SECRET: ${BLINKO_NEXTAUTH_SECRET}
|
|
||||||
DATABASE_URL: postgresql://blinko:blinko@blinko_db:5432/blinko
|
|
||||||
volumes:
|
|
||||||
- ../.data/blinko/app:/app/.blinko
|
|
||||||
depends_on:
|
|
||||||
db:
|
|
||||||
condition: service_healthy
|
|
||||||
restart: always
|
|
||||||
labels:
|
|
||||||
- "traefik.enable=true"
|
|
||||||
- "traefik.http.middlewares.blinko-redirect-web-secure.redirectscheme.scheme=https"
|
|
||||||
- "traefik.http.routers.blinko-web.middlewares=blinko-redirect-web-secure"
|
|
||||||
- "traefik.http.routers.blinko-web.rule=Host(`${TRAEFIK_HOST}`)"
|
|
||||||
- "traefik.http.routers.blinko-web.entrypoints=web"
|
|
||||||
- "traefik.http.routers.blinko-web-secure.rule=Host(`${TRAEFIK_HOST}`)"
|
|
||||||
- "traefik.http.routers.blinko-web-secure.tls.certresolver=resolver"
|
|
||||||
- "traefik.http.routers.blinko-web-secure.entrypoints=web-secure"
|
|
||||||
- "traefik.http.routers.blinko-web-secure.middlewares=security-headers@file,no-index@file"
|
|
||||||
- "traefik.http.services.blinko-web-secure.loadbalancer.server.port=1111"
|
|
||||||
- "traefik.docker.network=${NETWORK_NAME}"
|
|
||||||
- "com.centurylinklabs.watchtower.enable=true"
|
|
||||||
networks:
|
|
||||||
- compose_network
|
|
||||||
db:
|
|
||||||
image: postgres:14-alpine
|
|
||||||
container_name: blinko_db
|
|
||||||
environment:
|
|
||||||
POSTGRES_DB: blinko
|
|
||||||
POSTGRES_USER: blinko
|
|
||||||
POSTGRES_PASSWORD: blinko
|
|
||||||
volumes:
|
|
||||||
- ../.data/blinko/db:/var/lib/postgresql/data
|
|
||||||
restart: always
|
|
||||||
healthcheck:
|
|
||||||
test: ["CMD-SHELL", "pg_isready -U $${POSTGRES_USER} -d $${POSTGRES_DB}"]
|
|
||||||
interval: 5s
|
|
||||||
timeout: 5s
|
|
||||||
retries: 5
|
|
||||||
networks:
|
|
||||||
- compose_network
|
|
||||||
networks:
|
|
||||||
compose_network:
|
|
||||||
name: ${NETWORK_NAME}
|
|
||||||
external: true
|
|
||||||
Reference in New Issue
Block a user