a nice production stack on my laptop for my personal velociy system

This commit is contained in:
Charles N Wyble 2024-12-07 13:05:12 -06:00
parent 22bc3286ff
commit f3b4b31b5a
14 changed files with 171 additions and 74 deletions

View File

@ -1,44 +1,44 @@
services: services:
database: cleanslate-database:
image: postgres:15 image: postgres:15
restart: always restart: always
container_name: database container_name: cleanslate-database
ports: ports:
- '${POSTGRES_PORT:-5432}:5432' - '35000:5432'
environment: environment:
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD} POSTGRES_PASSWORD: 1234
volumes: volumes:
- database:/var/lib/postgresql/data - cleanslate-database:/var/lib/postgresql/data
healthcheck: healthcheck:
test: [ 'CMD-SHELL', 'pg_isready -U postgres'] test: [ 'CMD-SHELL', 'pg_isready -U postgres']
interval: 10s interval: 10s
timeout: 5s timeout: 5s
retries: 5 retries: 5
graphql-server: cleanslate-graphql-server:
image: hasura/graphql-engine:latest.cli-migrations-v3 image: hasura/graphql-engine:latest.cli-migrations-v3
restart: always restart: always
container_name: graphql-server container_name: cleanslate-graphql-server
ports: ports:
- '${HASURA_PORT:-8080}:8080' - '35001:8080'
environment: environment:
HASURA_GRAPHQL_ADMIN_SECRET: ${HASURA_GRAPHQL_ADMIN_SECRET} HASURA_GRAPHQL_ADMIN_SECRET: ${HASURA_GRAPHQL_ADMIN_SECRET}
HASURA_GRAPHQL_CORS_DOMAIN: https://${NEXT_PUBLIC_HASURA_DOMAIN} HASURA_GRAPHQL_CORS_DOMAIN: https://${NEXT_PUBLIC_HASURA_DOMAIN}
HASURA_GRAPHQL_DATABASE_URL: postgres://postgres:${POSTGRES_PASSWORD}@database:5432/postgres HASURA_GRAPHQL_DATABASE_URL: postgres://postgres:${POSTGRES_PASSWORD}@cleanslate-database:35000/postgres
HASURA_GRAPHQL_DEV_MODE: false HASURA_GRAPHQL_DEV_MODE: false
HASURA_GRAPHQL_ENABLE_CONSOLE: true HASURA_GRAPHQL_ENABLE_CONSOLE: true
HASURA_GRAPHQL_ENABLED_LOG_TYPES: startup, http-log, webhook-log, websocket-log, query-log HASURA_GRAPHQL_ENABLED_LOG_TYPES: startup, http-log, webhook-log, websocket-log, query-log
HASURA_GRAPHQL_JWT_SECRET: ${HASURA_GRAPHQL_JWT_SECRET} HASURA_GRAPHQL_JWT_SECRET: ${HASURA_GRAPHQL_JWT_SECRET}
volumes: volumes:
- ./migrations:/hasura-migrations - cleanslate-migrations:/hasura-migrations
- ./metadata:/hasura-metadata - cleanslate-metadata:/hasura-metadata
depends_on: depends_on:
database: cleanslate-database:
condition: service_healthy condition: service_healthy
extra_hosts: extra_hosts:
- 'host.docker.internal:host-gateway' - 'host.docker.internal:host-gateway'
authentication-server: cleanslate-authentication-server:
image: ghcr.io/successible/cleanslate/authentication-server:latest image: ghcr.io/successible/cleanslate/authentication-server:latest
build: build:
context: . context: .
@ -47,18 +47,18 @@ services:
restart: always restart: always
container_name: authentication-server container_name: authentication-server
ports: ports:
- '${AUTHENTICATION_SERVER_PORT:-3001}:3001' - '35002:3001'
environment: environment:
HASURA_GRAPHQL_ADMIN_SECRET: ${HASURA_GRAPHQL_ADMIN_SECRET} HASURA_GRAPHQL_ADMIN_SECRET: ${HASURA_GRAPHQL_ADMIN_SECRET}
JWT_SIGNING_SECRET: ${JWT_SIGNING_SECRET} JWT_SIGNING_SECRET: ${JWT_SIGNING_SECRET}
NEXT_PUBLIC_USE_FIREBASE: ${NEXT_PUBLIC_USE_FIREBASE:-false} NEXT_PUBLIC_USE_FIREBASE: ${NEXT_PUBLIC_USE_FIREBASE:-false}
depends_on: depends_on:
- database - cleanslate-database
- graphql-server - cleanslate-graphql-server
extra_hosts: extra_hosts:
- 'host.docker.internal:host-gateway' - 'host.docker.internal:host-gateway'
client: cleanslate-client:
image: ghcr.io/successible/cleanslate/client:latest image: ghcr.io/successible/cleanslate/client:latest
build: build:
context: . context: .
@ -77,12 +77,14 @@ services:
restart: always restart: always
container_name: client container_name: client
ports: ports:
- '${CLIENT_PORT:-3000}:3000' - '2010:3000'
depends_on: depends_on:
- database - cleanslate-database
- graphql-server - cleanslate-graphql-server
extra_hosts: extra_hosts:
- 'host.docker.internal:host-gateway' - 'host.docker.internal:host-gateway'
volumes: volumes:
database: cleanslate-database:
cleanslate-migrations:
cleanslate-metadata:

View File

@ -45,6 +45,11 @@
"category": "", "category": "",
"url": "http://tsys1:2006", "url": "http://tsys1:2006",
}, },
{
"name": "Reactive Resume",
"category": "",
"url": "http://tsys1:2007",
},
{ {
"name": "Atomic Habits", "name": "Atomic Habits",
"category": "", "category": "",

View File

@ -24,7 +24,7 @@ services:
# Storage (for image uploads) # Storage (for image uploads)
reactiveresume-minio: reactiveresume-minio:
image: minio/minio image: minio/minio
container_name: tsys-reactivereusme-minio container_name: tsys-reactiveresume-minio
restart: unless-stopped restart: unless-stopped
command: server /data command: server /data
ports: ports:

View File

@ -0,0 +1,63 @@
services:
tubearchivist:
container_name: tubearchivist
restart: unless-stopped
image: bbilly1/tubearchivist
ports:
- 2004:8000
volumes:
- tubearchivist-media:/youtube
- tubearchivist-cache:/cache
environment:
- ES_URL=http://tubearchivist-es:9200 # needs protocol e.g. http and port
- REDIS_HOST=tubearchivist-redis # don't add protocol
- HOST_UID=1000
- HOST_GID=1000
- TA_HOST=tsys1 # set your host name
- TA_USERNAME=tubearchivist # your initial TA credentials
- TA_PASSWORD=verysecret # your initial TA credentials
- ELASTIC_PASSWORD=verysecret # set password for Elasticsearch
- TZ=America/Chicago # set your time zone
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:2004/health"]
interval: 2m
timeout: 10s
retries: 3
start_period: 30s
depends_on:
- tubearchivist-es
- tubearchivist-redis
tubearchivist-redis:
image: redis/redis-stack-server
container_name: tubearchivist-redis
restart: unless-stopped
expose:
- "6379"
volumes:
- tubearchivist-redis:/data
depends_on:
- tubearchivist-es
tubearchivist-es:
image: bbilly1/tubearchivist-es # only for amd64, or use official es 8.14.3
container_name: tubearchivist-es
restart: unless-stopped
environment:
- "ELASTIC_PASSWORD=verysecret" # matching Elasticsearch password
- "ES_JAVA_OPTS=-Xms1g -Xmx1g"
- "xpack.security.enabled=true"
- "discovery.type=single-node"
- "path.repo=/usr/share/elasticsearch/data/snapshot"
ulimits:
memlock:
soft: -1
hard: -1
volumes:
- tubearchivist-es:/usr/share/elasticsearch/data # check for permission error when using bind mount, see readme
expose:
- "9200"
volumes:
tubearchivist-media:
tubearchivist-cache:
tubearchivist-redis:
tubearchivist-es:

View File

@ -0,0 +1,8 @@
services:
resume-matcher:
image : resume-matcher
build:
context: ./
dockerfile : build.dockerfile
ports:
- 80:8501

View File

@ -1,12 +0,0 @@
services:
wael:
container_name: reachableceo-wael
image: reachableceo-wael:latest # increment this number (or set the env value in your .env) to force portainer to rebuild the image https://github.com/portainer/portainer/issues/6288
restart: always
ports:
- "2009:3009" # Must be supplied by shell or in .env file
env_file:
- ./wael.env
volumes:
- "${HOST_DATA_PATH:-/default/path}:/workspace/prisma/data" # Must be supplied by shell or in .env file
user: node

View File

@ -1,5 +0,0 @@
TZ=America/Chicago
DOCKER_IMAGE_TAG=v2
HOST_DATA_PATH="D:/tsys/docker/volumes/reachableceo-wael-data/"
EXPOSE_PRISMA_STUDIO=false
PRISMA_STUDIO_PORT=5533

28
wger/config/nginx.conf Normal file
View File

@ -0,0 +1,28 @@
upstream wger {
server wger-web:2003;
}
server {
listen 80;
location / {
proxy_pass http://wger;
proxy_set_header Host $host;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $http_x_forwarded_proto;
proxy_set_header X-Forwarded-Host $host:$server_port;
proxy_redirect off;
}
location /static/ {
alias /wger/static/;
}
location /media/ {
alias /wger/media/;
}
# Increase max body size to allow for video uploads
client_max_body_size 100M;
}

View File

@ -1,4 +1,3 @@
#
# Please consult the `Deployment` section in the readme if you want to deploy # Please consult the `Deployment` section in the readme if you want to deploy
# this. You *need* to keep this nginx service, even if you have your own, # this. You *need* to keep this nginx service, even if you have your own,
# otherwise the static files will not be served correctly! If you do remove # otherwise the static files will not be served correctly! If you do remove
@ -6,35 +5,35 @@
# Also take a look at the "Static files" section in the .env file # Also take a look at the "Static files" section in the .env file
services: services:
web: wger-web:
image: wger/server:latest image: wger/server:latest
depends_on: depends_on:
db: wger-db:
condition: service_healthy condition: service_healthy
cache: wger-cache:
condition: service_healthy condition: service_healthy
env_file: #env_file:
- ./config/prod.env # - ./config/prod.env
volumes: volumes:
- static:/home/wger/static - wger-static:/home/wger/static
expose: expose:
- 8000 - 2003
healthcheck: healthcheck:
test: wget --no-verbose --tries=1 --spider http://localhost:2003 test: wget --no-verbose --tries=1 --spider http://localhost:8000
interval: 10s interval: 10s
timeout: 5s timeout: 5s
start_period: 300s start_period: 300s
retries: 5 retries: 5
restart: unless-stopped restart: unless-stopped
nginx: wger-nginx:
image: nginx:stable image: nginx:stable
depends_on: depends_on:
- web - wger-web
volumes: volumes:
- ./config/nginx.conf:/etc/nginx/conf.d/default.conf - ./config/nginx.conf:/etc/nginx/conf.d/default.conf
- static:/wger/static:ro - wger-static:/wger/static:ro
- media:/wger/media:ro - wger-media:/wger/media:ro
ports: ports:
- "80:80" - "80:80"
healthcheck: healthcheck:
@ -45,14 +44,14 @@ services:
start_period: 30s start_period: 30s
restart: unless-stopped restart: unless-stopped
db: wger-db:
image: postgres:15-alpine image: postgres:15-alpine
environment: environment:
- POSTGRES_USER=wger - POSTGRES_USER=wger
- POSTGRES_PASSWORD=wger - POSTGRES_PASSWORD=wger
- POSTGRES_DB=wger - POSTGRES_DB=wger
# volumes: volumes:
# - postgres-data:/var/lib/postgresql/data/ - wger-postgres-data:/var/lib/postgresql/data/
expose: expose:
- 5432 - 5432
healthcheck: healthcheck:
@ -63,12 +62,12 @@ services:
start_period: 30s start_period: 30s
restart: unless-stopped restart: unless-stopped
cache: wger-cache:
image: redis image: redis:latest
expose: expose:
- 6379 - 6379
volumes: volumes:
- redis-data:/data - wger-redis-data:/data
healthcheck: healthcheck:
test: redis-cli ping test: redis-cli ping
interval: 10s interval: 10s
@ -77,15 +76,15 @@ services:
start_period: 30s start_period: 30s
restart: unless-stopped restart: unless-stopped
celery_worker: wger-celery_worker:
image: wger/server:latest image: wger/server:latest
command: /start-worker command: /start-worker
env_file: #env_file:
- ./config/prod.env # - ./config/prod.env
volumes: volumes:
- media:/home/wger/media - wger-media:/home/wger/media
depends_on: depends_on:
web: wger-web:
condition: service_healthy condition: service_healthy
healthcheck: healthcheck:
test: celery -A wger inspect ping test: celery -A wger inspect ping
@ -94,23 +93,23 @@ services:
retries: 5 retries: 5
start_period: 30s start_period: 30s
celery_beat: wger-celery_beat:
image: wger/server:latest image: wger/server:latest
command: /start-beat command: /start-beat
volumes: volumes:
- celery-beat:/home/wger/beat/ - wger-celery-beat:/home/wger/beat/
env_file: #env_file:
- ./config/prod.env # - ./config/prod.env
depends_on: depends_on:
celery_worker: wger-celery_worker:
condition: service_healthy condition: service_healthy
volumes: volumes:
postgres-data: wger-postgres-data:
celery-beat: wger-celery-beat:
static: wger-static:
media: wger-media:
redis-data: wger-redis-data:
networks: networks:
default: default:

9
wger/update.sh Normal file
View File

@ -0,0 +1,9 @@
#!/bin/bash
#docker compose exec wger-web python3 manage.py sync-exercises
docker compose exec wger-web python3 manage.py download-exercise-images
docker compose exec wger-web python3 manage.py download-exercise-videos
docker compose exec wger-web wger load-online-fixtures
# afterwards:
docker compose exec wger-web python3 manage.py sync-ingredients