mirror of
https://github.com/zoriya/Kyoo.git
synced 2025-05-24 02:02:36 -04:00
Handle database connection vars
This commit is contained in:
parent
99b93f0f78
commit
c2ca1361fe
@ -20,7 +20,7 @@ IMAGES_PATH=./images
|
||||
# https://www.postgresql.org/docs/current/libpq-envars.html
|
||||
PGUSER=kyoo
|
||||
PGPASSWORD=password
|
||||
PGDATABASE=kyooDB
|
||||
PGDATABASE=kyoo
|
||||
PGHOST=postgres
|
||||
PGPORT=5432
|
||||
# PGOPTIONS=-c search_path=kyoo,public
|
||||
|
@ -1,188 +0,0 @@
|
||||
x-transcoder: &transcoder-base
|
||||
build:
|
||||
context: ./transcoder
|
||||
dockerfile: Dockerfile.dev
|
||||
networks:
|
||||
default:
|
||||
aliases:
|
||||
- transcoder
|
||||
ports:
|
||||
- "7666:7666"
|
||||
restart: on-failure
|
||||
cpus: 1
|
||||
env_file:
|
||||
- ./.env
|
||||
environment:
|
||||
- GOCODER_PREFIX=/video
|
||||
volumes:
|
||||
- ./transcoder:/app
|
||||
- ${LIBRARY_ROOT}:/video:ro
|
||||
- ${CACHE_ROOT}:/cache
|
||||
- transcoder_metadata:/metadata
|
||||
|
||||
services:
|
||||
front:
|
||||
build:
|
||||
context: ./front
|
||||
dockerfile: Dockerfile.dev
|
||||
volumes:
|
||||
- ./front:/app
|
||||
- /app/.yarn
|
||||
- /app/node_modules
|
||||
- /app/apps/mobile/node_modules
|
||||
- /app/apps/web/.next/
|
||||
- /app/apps/mobile/.expo/
|
||||
ports:
|
||||
- "3000:3000"
|
||||
- "8081:8081"
|
||||
restart: on-failure
|
||||
environment:
|
||||
- KYOO_URL=${KYOO_URL:-http://api:5000/api}
|
||||
labels:
|
||||
- "traefik.enable=true"
|
||||
- "traefik.http.routers.front.rule=PathPrefix(`/`)"
|
||||
|
||||
auth:
|
||||
build:
|
||||
context: ./auth
|
||||
dockerfile: Dockerfile.dev
|
||||
restart: on-failure
|
||||
depends_on:
|
||||
postgres:
|
||||
condition: service_healthy
|
||||
ports:
|
||||
- "4568:4568"
|
||||
env_file:
|
||||
- ./.env
|
||||
environment:
|
||||
- KEIBI_PREFIX=/auth
|
||||
volumes:
|
||||
- ./auth:/app
|
||||
labels:
|
||||
- "traefik.enable=true"
|
||||
- "traefik.http.routers.auth.rule=PathPrefix(`/auth/`) || PathPrefix(`/.well-known/`)"
|
||||
|
||||
api:
|
||||
build:
|
||||
context: ./api
|
||||
dockerfile: Dockerfile.dev
|
||||
restart: on-failure
|
||||
depends_on:
|
||||
postgres:
|
||||
condition: service_healthy
|
||||
volumes:
|
||||
- ./api:/app
|
||||
- /app/node_modules
|
||||
ports:
|
||||
- "3567:3567"
|
||||
environment:
|
||||
- KYOO_PREFIX=/api
|
||||
- JWT_ISSUER=${PUBLIC_URL}
|
||||
env_file:
|
||||
- ./.env
|
||||
labels:
|
||||
- "traefik.enable=true"
|
||||
- "traefik.http.routers.api.rule=PathPrefix(`/api/`) || PathPrefix(`/swagger`)"
|
||||
- "traefik.http.routers.api.middlewares=phantom-token"
|
||||
- "traefik.http.middlewares.phantom-token.forwardauth.address=http://auth:4568/auth/jwt"
|
||||
- "traefik.http.middlewares.phantom-token.forwardauth.authRequestHeaders=Authorization,X-Api-Key"
|
||||
- "traefik.http.middlewares.phantom-token.forwardauth.authResponseHeaders=Authorization"
|
||||
|
||||
# scanner:
|
||||
# build: ./scanner
|
||||
# restart: on-failure
|
||||
# depends_on:
|
||||
# back:
|
||||
# condition: service_healthy
|
||||
# env_file:
|
||||
# - ./.env
|
||||
# environment:
|
||||
# - KYOO_URL=${KYOO_URL:-http://back:5000/api}
|
||||
# volumes:
|
||||
# - ${LIBRARY_ROOT}:/video:ro
|
||||
#
|
||||
# matcher:
|
||||
# build: ./scanner
|
||||
# command: matcher
|
||||
# restart: on-failure
|
||||
# depends_on:
|
||||
# back:
|
||||
# condition: service_healthy
|
||||
# env_file:
|
||||
# - ./.env
|
||||
# environment:
|
||||
# - KYOO_URL=${KYOO_URL:-http://back:5000/api}
|
||||
|
||||
transcoder:
|
||||
<<: *transcoder-base
|
||||
profiles: ['', 'cpu']
|
||||
|
||||
transcoder-nvidia:
|
||||
<<: *transcoder-base
|
||||
deploy:
|
||||
resources:
|
||||
reservations:
|
||||
devices:
|
||||
- capabilities: [gpu]
|
||||
driver: cdi
|
||||
device_ids:
|
||||
- nvidia.com/gpu=all
|
||||
environment:
|
||||
- GOCODER_PREFIX=/video
|
||||
- GOCODER_HWACCEL=nvidia
|
||||
profiles: ['nvidia']
|
||||
|
||||
transcoder-vaapi:
|
||||
<<: *transcoder-base
|
||||
devices:
|
||||
- /dev/dri:/dev/dri
|
||||
environment:
|
||||
- GOCODER_PREFIX=/video
|
||||
- GOCODER_HWACCEL=vaapi
|
||||
- GOCODER_VAAPI_RENDERER=${GOCODER_VAAPI_RENDERER:-/dev/dri/renderD128}
|
||||
profiles: ['vaapi']
|
||||
# qsv is the same setup as vaapi but with the hwaccel env var different
|
||||
transcoder-qsv:
|
||||
<<: *transcoder-base
|
||||
devices:
|
||||
- /dev/dri:/dev/dri
|
||||
environment:
|
||||
- GOCODER_PREFIX=/video
|
||||
- GOCODER_HWACCEL=qsv
|
||||
- GOCODER_VAAPI_RENDERER=${GOCODER_VAAPI_RENDERER:-/dev/dri/renderD128}
|
||||
profiles: ['qsv']
|
||||
|
||||
traefik:
|
||||
image: traefik:v3.4
|
||||
restart: on-failure
|
||||
command:
|
||||
- "--providers.docker=true"
|
||||
- "--providers.docker.exposedbydefault=false"
|
||||
- "--entryPoints.web.address=:8901"
|
||||
- "--accesslog=true"
|
||||
ports:
|
||||
- "8901:8901"
|
||||
volumes:
|
||||
- "/var/run/docker.sock:/var/run/docker.sock:ro"
|
||||
|
||||
postgres:
|
||||
image: postgres:15
|
||||
restart: on-failure
|
||||
env_file:
|
||||
- ./.env
|
||||
volumes:
|
||||
- db:/var/lib/postgresql/data
|
||||
ports:
|
||||
- "5432:5432"
|
||||
environment:
|
||||
- POSTGRES_HOST_AUTH_METHOD=trust
|
||||
command: ["postgres", "-c", "log_statement=all"]
|
||||
healthcheck:
|
||||
test: ["CMD-SHELL", "pg_isready -U ${POSTGRES_USER} -d ${POSTGRES_DB}"]
|
||||
interval: 5s
|
||||
timeout: 5s
|
||||
retries: 5
|
||||
|
||||
volumes:
|
||||
db:
|
||||
transcoder_metadata:
|
@ -104,6 +104,8 @@ services:
|
||||
- "4389:4389"
|
||||
environment:
|
||||
- KYOO_URL=${KYOO_URL:-http://api:3567/api}
|
||||
- JWKS_URL="http://auth:4568/.well-known/jwks.json"
|
||||
- JWT_ISSUER=${PUBLIC_URL}
|
||||
volumes:
|
||||
- ./scanner:/app
|
||||
- ${LIBRARY_ROOT}:/video:ro
|
||||
|
@ -20,6 +20,6 @@ JWT_ISSUER=$PUBLIC_URL
|
||||
# https://www.postgresql.org/docs/current/libpq-envars.html
|
||||
PGUSER=kyoo
|
||||
PGPASSWORD=password
|
||||
PGDATABASE=kyooDB
|
||||
PGDATABASE=kyoo
|
||||
PGHOST=postgres
|
||||
PGPORT=5432
|
||||
|
@ -17,7 +17,6 @@ logging.getLogger("rebulk").setLevel(logging.WARNING)
|
||||
|
||||
@asynccontextmanager
|
||||
async def lifespan(_):
|
||||
print("starting lifetime")
|
||||
async with (
|
||||
init_pool(),
|
||||
get_db() as db,
|
||||
@ -34,7 +33,6 @@ async def lifespan(_):
|
||||
# there's no way someone else used the same id, right?
|
||||
is_master = await db.fetchval("select pg_try_advisory_lock(198347)")
|
||||
if is_master:
|
||||
print("this is master")
|
||||
_ = await asyncio.create_task(scanner.scan(remove_deleted=True))
|
||||
_ = await asyncio.create_task(scanner.monitor())
|
||||
yield
|
||||
|
@ -1,5 +1,6 @@
|
||||
import os
|
||||
from contextlib import asynccontextmanager
|
||||
from typing import cast
|
||||
from typing import Any, cast
|
||||
|
||||
from asyncpg import Connection, Pool, create_pool
|
||||
|
||||
@ -8,7 +9,17 @@ pool: Pool
|
||||
|
||||
@asynccontextmanager
|
||||
async def init_pool():
|
||||
async with await create_pool() as p:
|
||||
url = os.environ.get("POSTGRES_URL")
|
||||
connection: dict[str, Any] = (
|
||||
{
|
||||
"user": os.environ.get("PGUSER", "kyoo"),
|
||||
"host": os.environ.get("PGHOST", "postgres"),
|
||||
"password": os.environ.get("PGPASSWORD", "password"),
|
||||
}
|
||||
if url is None
|
||||
else {"dns": url}
|
||||
)
|
||||
async with await create_pool(**connection) as p:
|
||||
global pool
|
||||
pool = p
|
||||
yield
|
||||
|
Loading…
x
Reference in New Issue
Block a user