diff --git a/Dockerfile b/Dockerfile index 470273b..3ecdb21 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,33 +1,33 @@ -FROM node:lts-alpine AS builder +# syntax=docker/dockerfile:1.7 + +ARG NODE_VERSION=lts + +FROM node:${NODE_VERSION}-alpine AS base WORKDIR /app +RUN npm install -g pnpm -RUN npm i -g pnpm +FROM base AS deps RUN apk add --no-cache python3 make g++ - COPY package.json pnpm-lock.yaml ./ +RUN pnpm install --frozen-lockfile -RUN pnpm install - +FROM deps AS builder COPY . . RUN pnpm run build +RUN pnpm prune --prod -FROM node:lts-alpine AS runtime +FROM node:${NODE_VERSION}-alpine AS runtime WORKDIR /app - -RUN npm i -g pnpm - +ENV NODE_ENV=production +ENV HOST=0.0.0.0 +ENV PORT=4321 +ENV DATABASE_URL=/app/data/chronus.db +RUN apk add --no-cache libstdc++ COPY --from=builder /app/dist ./dist COPY --from=builder /app/drizzle ./drizzle COPY --from=builder /app/scripts ./scripts COPY package.json pnpm-lock.yaml ./ - -RUN pnpm install --prod - +COPY --from=builder /app/node_modules ./node_modules RUN mkdir -p /app/data - -ENV HOST=0.0.0.0 -ENV PORT=4321 -ENV DATABASE_URL=/app/data/chronus.db EXPOSE 4321 - -CMD ["sh", "-c", "pnpm run migrate && node ./dist/server/entry.mjs"] +CMD ["sh","-c","node scripts/migrate.js && node ./dist/server/entry.mjs"]