deploy(manavoxel): add Dockerfile, docker-compose, and deploy config

- Dockerfile: two-stage build on sveltekit-base, port 5028
- docker-compose.macmini.yml: manavoxel-web service on port 5028
- Root package.json: dev:manavoxel:web and dev:manavoxel:full scripts
- Fix Tailwind CSS import (shared-tailwind/themes.css)
- Port changed from 5195 to 5028 (consistent dev/prod)

Deploy with: ./scripts/mac-mini/build-app.sh manavoxel-web

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
This commit is contained in:
Till JS 2026-03-29 14:56:32 +02:00
parent 0806600bc0
commit 35ec9aeb2e
5 changed files with 82 additions and 14 deletions

View file

@ -0,0 +1,41 @@
# syntax=docker/dockerfile:1
# ─── Stage 1: Build ──────────────────────────────────────────
FROM sveltekit-base:local AS builder
ARG PUBLIC_MANA_CORE_AUTH_URL=http://mana-auth:3001
ARG PUBLIC_SYNC_SERVER_URL=http://mana-sync:3010
ENV PUBLIC_MANA_CORE_AUTH_URL=$PUBLIC_MANA_CORE_AUTH_URL
ENV PUBLIC_SYNC_SERVER_URL=$PUBLIC_SYNC_SERVER_URL
# Copy app-specific packages
COPY apps/manavoxel/packages/shared ./apps/manavoxel/packages/shared
COPY apps/manavoxel/apps/web ./apps/manavoxel/apps/web
RUN --mount=type=cache,id=pnpm,target=/root/.local/share/pnpm/store \
pnpm install --no-frozen-lockfile --ignore-scripts
WORKDIR /app/apps/manavoxel/apps/web
RUN pnpm exec svelte-kit sync
RUN NODE_OPTIONS="--max-old-space-size=4096" pnpm build
# ─── Stage 2: Production ─────────────────────────────────────
FROM node:20-alpine AS production
WORKDIR /app/apps/manavoxel/apps/web
COPY --from=builder /app/node_modules/.pnpm /app/node_modules/.pnpm
COPY --from=builder /app/apps/manavoxel/apps/web/node_modules ./node_modules
COPY --from=builder /app/apps/manavoxel/apps/web/build ./build
COPY --from=builder /app/apps/manavoxel/apps/web/package.json ./
EXPOSE 5028
ENV NODE_ENV=production
ENV PORT=5028
ENV HOST=0.0.0.0
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
CMD wget --no-verbose --tries=1 --spider http://localhost:5028/health || exit 1
CMD ["node", "build"]

View file

@ -1,5 +1,5 @@
@import 'tailwindcss';
@import '@manacore/shared-tailwind';
@import '@manacore/shared-tailwind/themes.css';
/* ManaVoxel specific styles */
:root {

View file

@ -35,7 +35,7 @@ export default defineConfig({
),
],
server: {
port: 5195,
port: 5028,
strictPort: true,
},
ssr: {

View file

@ -95,9 +95,12 @@ services:
container_name: mana-infra-landings
restart: always
volumes:
- ./docker/nginx/landings.conf:/etc/nginx/conf.d/default.conf:ro
- ./docker/nginx/snippets:/etc/nginx/snippets:ro
- ./docker/nginx:/etc/nginx/host-config:ro
- /Volumes/ManaData/landings:/srv/landings:ro
command: >
sh -c "cp /etc/nginx/host-config/landings.conf /etc/nginx/conf.d/default.conf &&
cp -r /etc/nginx/host-config/snippets/* /etc/nginx/snippets/ 2>/dev/null;
nginx -g 'daemon off;'"
ports:
- "4400:80"
healthcheck:
@ -438,8 +441,7 @@ services:
container_name: mana-core-searxng
restart: always
volumes:
- ./services/mana-search/searxng/settings.yml:/etc/searxng/settings.yml:ro
- ./services/mana-search/searxng/limiter.toml:/etc/searxng/limiter.toml:ro
- ./services/mana-search/searxng:/etc/searxng:ro
environment:
SEARXNG_BASE_URL: http://searxng:8080
SEARXNG_SECRET: ${SEARXNG_SECRET:-change-me-searxng-secret}
@ -672,9 +674,7 @@ services:
SYNAPSE_REGISTRATION_SECRET: ${SYNAPSE_REGISTRATION_SECRET:-change-me-registration-secret}
SYNAPSE_OIDC_CLIENT_SECRET: ${SYNAPSE_OIDC_CLIENT_SECRET}
volumes:
- ./docker/matrix/homeserver.yaml:/config/homeserver.yaml:ro
- ./docker/matrix/log.config.yaml:/config/log.config.yaml:ro
- ./docker/matrix/appservices:/appservices:ro
- ./docker/matrix/config:/config:ro
- ./docker/matrix/data:/data
ports:
- "4000:8008"
@ -1297,6 +1297,31 @@ services:
retries: 3
start_period: 20s
manavoxel-web:
build:
context: .
dockerfile: apps/manavoxel/apps/web/Dockerfile
image: manavoxel-web:local
container_name: mana-app-manavoxel-web
restart: always
depends_on:
mana-auth:
condition: service_healthy
environment:
NODE_ENV: production
PORT: 5028
PUBLIC_MANA_CORE_AUTH_URL: http://mana-auth:3001
PUBLIC_MANA_CORE_AUTH_URL_CLIENT: https://auth.mana.how
PUBLIC_SYNC_SERVER_URL: ws://mana-sync:3010
ports:
- "5028:5028"
healthcheck:
test: ["CMD", "wget", "--no-verbose", "--tries=1", "--spider", "http://127.0.0.1:5028/health"]
interval: 180s
timeout: 10s
retries: 3
start_period: 45s
mana-llm:
build:
context: ./services/mana-llm
@ -1307,7 +1332,7 @@ services:
redis:
condition: service_healthy
environment:
PORT: 3020
PORT: 3025
LOG_LEVEL: info
OLLAMA_URL: ${OLLAMA_URL:-http://192.168.178.11:11434}
OLLAMA_DEFAULT_MODEL: ${OLLAMA_MODEL:-gemma3:12b}
@ -1431,8 +1456,7 @@ services:
- '-selfScrapeInterval=15s'
- '-search.latencyOffset=0s'
volumes:
- ./docker/prometheus/prometheus.yml:/etc/prometheus/prometheus.yml:ro
- ./docker/prometheus/alerts.yml:/etc/prometheus/alerts.yml:ro
- ./docker/prometheus:/etc/prometheus:ro
- victoriametrics_data:/storage
ports:
- "9090:9090"
@ -1449,7 +1473,7 @@ services:
restart: always
command: -config.file=/etc/loki/local-config.yaml
volumes:
- ./docker/loki/local-config.yaml:/etc/loki/local-config.yaml:ro
- ./docker/loki:/etc/loki:ro
- loki_data:/loki
ports:
- "3100:3100"
@ -1565,7 +1589,7 @@ services:
- '-evaluationInterval=30s'
- '-httpListenAddr=:8880'
volumes:
- ./docker/prometheus/alerts.yml:/etc/alerts/alerts.yml:ro
- ./docker/prometheus:/etc/alerts:ro
ports:
- "8880:8880"
healthcheck:

View file

@ -125,6 +125,9 @@
"taktik:dev": "turbo run dev --filter=taktik...",
"dev:taktik:web": "pnpm --filter @taktik/web dev",
"dev:taktik:full": "concurrently -n auth,sync,web -c blue,magenta,cyan \"pnpm dev:auth\" \"pnpm dev:sync\" \"pnpm dev:taktik:web\"",
"manavoxel:dev": "turbo run dev --filter=manavoxel...",
"dev:manavoxel:web": "pnpm --filter @manavoxel/web dev",
"dev:manavoxel:full": "concurrently -n auth,sync,web -c blue,magenta,cyan \"pnpm dev:auth\" \"pnpm dev:sync\" \"pnpm dev:manavoxel:web\"",
"calc:dev": "turbo run dev --filter=calc...",
"dev:calc:web": "pnpm --filter @calc/web dev",
"dev:calc:app": "pnpm dev:calc:web",