mirror of
https://github.com/kyantech/Palmr.git
synced 2025-10-22 22:02:00 +00:00
- Added a new `docker-compose-bind-mount-example.yaml` for easier bind mount configuration. - Updated `.gitignore` to include the `data/` directory for persistent storage. - Modified `docker-compose.yaml` to clarify volume paths and improve comments. - Enhanced `Dockerfile` to support flexible UID/GID configuration and ensure proper directory permissions. - Updated environment variable handling in `server-start.sh` and Prisma configuration for better database management. - Revised documentation in `quick-start.mdx` and `uid-gid-configuration.mdx` to reflect new features and best practices for deployment.
193 lines
5.3 KiB
Docker
193 lines
5.3 KiB
Docker
FROM node:20-alpine AS base
|
|
|
|
# Install system dependencies
|
|
RUN apk add --no-cache \
|
|
gcompat \
|
|
supervisor \
|
|
curl \
|
|
su-exec
|
|
|
|
# Enable pnpm
|
|
RUN corepack enable pnpm
|
|
|
|
# Set working directory
|
|
WORKDIR /app
|
|
|
|
# === SERVER BUILD STAGE ===
|
|
FROM base AS server-deps
|
|
WORKDIR /app/server
|
|
|
|
# Copy server package files
|
|
COPY apps/server/package*.json ./
|
|
COPY apps/server/pnpm-lock.yaml ./
|
|
|
|
# Install server dependencies
|
|
RUN pnpm install --frozen-lockfile
|
|
|
|
FROM base AS server-builder
|
|
WORKDIR /app/server
|
|
|
|
# Copy server dependencies
|
|
COPY --from=server-deps /app/server/node_modules ./node_modules
|
|
|
|
# Copy server source code
|
|
COPY apps/server/ ./
|
|
|
|
# Generate Prisma client
|
|
RUN npx prisma generate
|
|
|
|
# Build server
|
|
RUN pnpm build
|
|
|
|
# === WEB BUILD STAGE ===
|
|
FROM base AS web-deps
|
|
WORKDIR /app/web
|
|
|
|
# Copy web package files
|
|
COPY apps/web/package.json apps/web/pnpm-lock.yaml ./
|
|
|
|
# Install web dependencies
|
|
RUN pnpm install --frozen-lockfile
|
|
|
|
FROM base AS web-builder
|
|
WORKDIR /app/web
|
|
|
|
# Copy web dependencies
|
|
COPY --from=web-deps /app/web/node_modules ./node_modules
|
|
|
|
# Copy web source code
|
|
COPY apps/web/ ./
|
|
|
|
# Set environment variables for build
|
|
ENV NEXT_TELEMETRY_DISABLED=1
|
|
ENV NODE_ENV=production
|
|
|
|
# Build web application
|
|
RUN pnpm run build
|
|
|
|
# === PRODUCTION STAGE ===
|
|
FROM base AS runner
|
|
|
|
# Set production environment
|
|
ENV NODE_ENV=production
|
|
ENV NEXT_TELEMETRY_DISABLED=1
|
|
ENV API_BASE_URL=http://127.0.0.1:3333
|
|
|
|
# Define build arguments for user/group configuration (defaults to current values)
|
|
ARG PALMR_UID=1001
|
|
ARG PALMR_GID=1001
|
|
|
|
# Create application user with configurable UID/GID
|
|
RUN addgroup --system --gid ${PALMR_GID} nodejs
|
|
RUN adduser --system --uid ${PALMR_UID} --ingroup nodejs palmr
|
|
|
|
# Create application directories
|
|
RUN mkdir -p /app/palmr-app /app/web /home/palmr/.npm /home/palmr/.cache
|
|
RUN chown -R palmr:nodejs /app /home/palmr
|
|
|
|
# === Copy Server Files to /app/palmr-app (separate from /app/server for bind mounts) ===
|
|
WORKDIR /app/palmr-app
|
|
|
|
# Copy server production files
|
|
COPY --from=server-builder --chown=palmr:nodejs /app/server/dist ./dist
|
|
COPY --from=server-builder --chown=palmr:nodejs /app/server/node_modules ./node_modules
|
|
COPY --from=server-builder --chown=palmr:nodejs /app/server/prisma ./prisma
|
|
COPY --from=server-builder --chown=palmr:nodejs /app/server/package.json ./
|
|
|
|
# Copy password reset script and make it executable
|
|
COPY --from=server-builder --chown=palmr:nodejs /app/server/reset-password.sh ./
|
|
COPY --from=server-builder --chown=palmr:nodejs /app/server/src/scripts/ ./src/scripts/
|
|
RUN chmod +x ./reset-password.sh
|
|
|
|
# Copy seed file to the shared location for bind mounts
|
|
RUN mkdir -p /app/server/prisma
|
|
COPY --from=server-builder --chown=palmr:nodejs /app/server/prisma/seed.js /app/server/prisma/seed.js
|
|
|
|
# === Copy Web Files ===
|
|
WORKDIR /app/web
|
|
|
|
# Copy web production files
|
|
COPY --from=web-builder --chown=palmr:nodejs /app/web/public ./public
|
|
COPY --from=web-builder --chown=palmr:nodejs /app/web/.next/standalone ./
|
|
COPY --from=web-builder --chown=palmr:nodejs /app/web/.next/static ./.next/static
|
|
|
|
# === Setup Supervisor ===
|
|
WORKDIR /app
|
|
|
|
# Create supervisor configuration
|
|
RUN mkdir -p /etc/supervisor/conf.d /var/log/supervisor
|
|
|
|
# Copy server start script
|
|
COPY infra/server-start.sh /app/server-start.sh
|
|
RUN chmod +x /app/server-start.sh
|
|
RUN chown palmr:nodejs /app/server-start.sh
|
|
|
|
# Copy supervisor configuration (updated paths)
|
|
COPY <<EOF /etc/supervisor/conf.d/supervisord.conf
|
|
[supervisord]
|
|
nodaemon=true
|
|
user=root
|
|
logfile=/var/log/supervisor/supervisord.log
|
|
pidfile=/var/run/supervisord.pid
|
|
|
|
[program:server]
|
|
command=/bin/sh -c "export DATABASE_URL='file:/app/server/prisma/palmr.db' && export UPLOAD_PATH='/app/server/uploads' && export TEMP_CHUNKS_PATH='/app/server/temp-chunks' && /app/server-start.sh"
|
|
directory=/app/palmr-app
|
|
user=root
|
|
autostart=true
|
|
autorestart=true
|
|
stderr_logfile=/var/log/supervisor/server.err.log
|
|
stdout_logfile=/var/log/supervisor/server.out.log
|
|
environment=PORT=3333,HOME="/home/palmr"
|
|
priority=100
|
|
|
|
[program:web]
|
|
command=/bin/sh -c 'echo "Waiting for API to be ready..."; while ! curl -f http://127.0.0.1:3333/health >/dev/null 2>&1; do echo "API not ready, waiting..."; sleep 2; done; echo "API is ready! Starting frontend..."; exec node server.js'
|
|
directory=/app/web
|
|
user=palmr
|
|
autostart=true
|
|
autorestart=true
|
|
stderr_logfile=/var/log/supervisor/web.err.log
|
|
stdout_logfile=/var/log/supervisor/web.out.log
|
|
environment=PORT=5487,HOSTNAME="0.0.0.0",HOME="/home/palmr",API_BASE_URL="http://127.0.0.1:3333"
|
|
priority=200
|
|
startsecs=10
|
|
EOF
|
|
|
|
# Create main startup script
|
|
COPY <<EOF /app/start.sh
|
|
#!/bin/sh
|
|
set -e
|
|
|
|
echo "Starting Palmr Application..."
|
|
echo "Storage Mode: \${ENABLE_S3:-false}"
|
|
echo "Database: SQLite"
|
|
|
|
# Set global environment variables
|
|
export DATABASE_URL="file:/app/server/prisma/palmr.db"
|
|
export UPLOAD_PATH="/app/server/uploads"
|
|
export TEMP_CHUNKS_PATH="/app/server/temp-chunks"
|
|
|
|
# Ensure /app/server directory exists for bind mounts
|
|
mkdir -p /app/server/uploads /app/server/temp-chunks /app/server/uploads/logo /app/server/prisma
|
|
|
|
echo "Data directories ready for first run..."
|
|
|
|
# Start supervisor
|
|
exec /usr/bin/supervisord -c /etc/supervisor/conf.d/supervisord.conf
|
|
EOF
|
|
|
|
RUN chmod +x /app/start.sh
|
|
|
|
# Create volume mount points for bind mounts
|
|
VOLUME ["/app/server"]
|
|
|
|
# Expose ports
|
|
EXPOSE 3333 5487
|
|
|
|
# Health check
|
|
HEALTHCHECK --interval=30s --timeout=10s --start-period=60s --retries=3 \
|
|
CMD curl -f http://localhost:5487 || exit 1
|
|
|
|
# Start application
|
|
CMD ["/app/start.sh"] |