Improved docker workflow

This commit is contained in:
Aron Malcher 2024-01-05 03:26:21 +01:00
parent 3379a685e1
commit 1d4f7e6fc6
Signed by: aronmal
GPG key ID: 816B7707426FC612
4 changed files with 16 additions and 596 deletions

View file

@ -1,5 +1,7 @@
FROM node:21-alpine AS base
ENV NODE_ENV production
# Install dependencies only when needed
FROM base AS deps
# Check https://github.com/nodejs/docker-node/tree/b4117f9333da4138b03a546ec926ef50a31506c3#nodealpine to understand why libc6-compat might be needed.
@ -9,8 +11,9 @@ WORKDIR /app
# Install dependencies based on the preferred package manager
COPY package.json yarn.lock* package-lock.json* pnpm-lock.yaml* ./
RUN \
if [ -f package-lock.json ]; then npm ci; \
elif [ -f pnpm-lock.yaml ]; then npm install --global pnpm && pnpm i --frozen-lockfile; \
if [ -f yarn.lock ]; then yarn --frozen-lockfile; \
elif [ -f package-lock.json ]; then npm ci; \
elif [ -f pnpm-lock.yaml ]; then yarn global add pnpm && pnpm i --frozen-lockfile; \
else echo "Lockfile not found." && exit 1; \
fi
@ -27,8 +30,6 @@ RUN npm run build
FROM base AS runner
WORKDIR /app
ENV NODE_ENV production
RUN addgroup --system --gid 1001 nodejs
RUN adduser --system --uid 1001 solidjs
@ -37,8 +38,6 @@ COPY --from=builder /app/public ./public
COPY --from=builder --chown=solidjs:nodejs /app/.output ./.output
COPY --from=builder --chown=solidjs:nodejs /app/.vinxi ./.vinxi
RUN npm install vinxi
USER solidjs
EXPOSE 3000
@ -47,4 +46,4 @@ ENV PORT 3000
# set hostname to localhost
ENV HOSTNAME "0.0.0.0"
CMD ["npx", "vinxi", "start"]
CMD ["node", ".output/server/index.mjs"]