fix(docker): reduce Docker size + improve security

This commit is contained in:
Damien Laureaux 2024-10-24 16:22:27 +02:00
parent 18529391f4
commit 652e665726
No known key found for this signature in database
GPG key ID: 3802EADA1C1C604D
3 changed files with 70 additions and 20 deletions

View file

@ -1,16 +1,45 @@
#############################
# Build stage
#############################
FROM node:18-slim AS builder
WORKDIR /app
# Copy package.json and yarn.lock
COPY package.json yarn.lock ./
# Copy the rest of the application code
COPY tsconfig.json drizzle.config.ts ./
COPY src ./src
# Install dependencies & build the application
RUN yarn install --frozen-lockfile --network-timeout 600000 && yarn build
#############################
# Production stage
#############################
FROM node:18-slim
WORKDIR /home/perplexica
WORKDIR /app
COPY src /home/perplexica/src
COPY tsconfig.json /home/perplexica/
COPY drizzle.config.ts /home/perplexica/
COPY package.json /home/perplexica/
COPY yarn.lock /home/perplexica/
# Copy built assets and necessary files from the builder stage
COPY --chown=node:node --from=builder /app/dist ./dist
COPY --chown=node:node --from=builder /app/node_modules ./node_modules
RUN mkdir /home/perplexica/data
# Copy the rest of the application code
COPY --chown=node:node ./drizzle.config.ts ./
COPY --chown=node:node ./tsconfig.json ./
COPY --chown=node:node ./src/db/schema.ts ./src/db/schema.ts
COPY --chown=node:node ./package.json ./package.json
RUN yarn install --frozen-lockfile --network-timeout 600000
RUN yarn build
# Create data directory & set permissions to node user
RUN mkdir /app/data && \
chown -R node:node /app/data
# Run the Docker image as node instead of root
USER node
# Start the application
CMD ["yarn", "start"]