update Dockerfiles based on official example
This commit is contained in:
+8
-4
@@ -1,7 +1,13 @@
|
|||||||
|
Dockerfile
|
||||||
|
Dockerfile.prod
|
||||||
|
.dockerignore
|
||||||
|
node_modules
|
||||||
|
npm-debug.log
|
||||||
|
README*
|
||||||
|
LICENSE
|
||||||
.next
|
.next
|
||||||
.vscode
|
.vscode
|
||||||
e2e-screenshots
|
e2e-screenshots
|
||||||
node_modules
|
|
||||||
tests
|
tests
|
||||||
.env*
|
.env*
|
||||||
.eslintrc.json
|
.eslintrc.json
|
||||||
@@ -10,6 +16,4 @@ tests
|
|||||||
.gitlab-ci.yml
|
.gitlab-ci.yml
|
||||||
.nvmrc
|
.nvmrc
|
||||||
.stylelintrc
|
.stylelintrc
|
||||||
LICENSE
|
stack-compose*
|
||||||
README*
|
|
||||||
stack-compose*
|
|
||||||
|
|||||||
+29
-14
@@ -1,26 +1,41 @@
|
|||||||
FROM node:14-alpine as builder
|
# Install dependencies only when needed
|
||||||
|
FROM node:14-alpine AS deps
|
||||||
|
# Check https://github.com/nodejs/docker-node/tree/b4117f9333da4138b03a546ec926ef50a31506c3#nodealpine to understand why libc6-compat might be needed.
|
||||||
|
RUN apk add --no-cache libc6-compat
|
||||||
|
WORKDIR /app
|
||||||
COPY package.json package-lock.json ./
|
COPY package.json package-lock.json ./
|
||||||
RUN npm install
|
RUN npm ci
|
||||||
|
|
||||||
COPY tsconfig.json next-env.d.ts .babelrc next.config.js next-sitemap.js ./
|
# Rebuild the source code only when needed
|
||||||
COPY src src/
|
FROM node:14-alpine AS builder
|
||||||
COPY public public/
|
WORKDIR /app
|
||||||
COPY types types/
|
COPY . .
|
||||||
|
COPY --from=deps /app/node_modules ./node_modules
|
||||||
|
|
||||||
ENV NEXT_TELEMETRY_DISABLED=1
|
ENV NEXT_TELEMETRY_DISABLED=1
|
||||||
ENV NEXT_PUBLIC_API_URL=https://api.dev.sahkoinsinoorikilta.fi/api
|
ENV NEXT_PUBLIC_API_URL=https://api.dev.sahkoinsinoorikilta.fi/api
|
||||||
ENV NEXT_PUBLIC_SITE_URL=https://dev.sahkoinsinoorikilta.fi
|
ENV NEXT_PUBLIC_SITE_URL=https://dev.sahkoinsinoorikilta.fi
|
||||||
RUN npm run build
|
RUN npm run build
|
||||||
|
|
||||||
FROM node:14-alpine as server
|
# Production image, copy all the files and run next
|
||||||
WORKDIR /www
|
FROM node:14-alpine AS runner
|
||||||
COPY package.json package-lock.json next.config.js next-sitemap.js ./
|
WORKDIR /app
|
||||||
COPY --from=builder .next .next
|
|
||||||
COPY --from=builder node_modules node_modules
|
ENV NODE_ENV production
|
||||||
COPY --from=builder public public
|
|
||||||
|
COPY --from=builder /app/next.config.js ./
|
||||||
|
COPY --from=builder /app/public ./public
|
||||||
|
COPY --from=builder /app/.next ./.next
|
||||||
|
COPY --from=builder /app/node_modules ./node_modules
|
||||||
|
COPY --from=builder /app/package.json ./package.json
|
||||||
|
|
||||||
RUN npm prune --production
|
RUN npm prune --production
|
||||||
|
|
||||||
|
RUN addgroup -g 1001 -S nodejs
|
||||||
|
RUN adduser -S nextjs -u 1001
|
||||||
|
RUN chown -R nextjs:nodejs /app/.next
|
||||||
|
USER nextjs
|
||||||
|
|
||||||
EXPOSE 3000
|
EXPOSE 3000
|
||||||
ENTRYPOINT ["npm", "run", "serve"]
|
|
||||||
|
CMD ["npm", "run", "serve"]
|
||||||
|
|||||||
+29
-14
@@ -1,26 +1,41 @@
|
|||||||
FROM node:14-alpine as builder
|
# Install dependencies only when needed
|
||||||
|
FROM node:14-alpine AS deps
|
||||||
|
# Check https://github.com/nodejs/docker-node/tree/b4117f9333da4138b03a546ec926ef50a31506c3#nodealpine to understand why libc6-compat might be needed.
|
||||||
|
RUN apk add --no-cache libc6-compat
|
||||||
|
WORKDIR /app
|
||||||
COPY package.json package-lock.json ./
|
COPY package.json package-lock.json ./
|
||||||
RUN npm install
|
RUN npm ci
|
||||||
|
|
||||||
COPY tsconfig.json next-env.d.ts .babelrc next.config.js next-sitemap.js ./
|
# Rebuild the source code only when needed
|
||||||
COPY src src/
|
FROM node:14-alpine AS builder
|
||||||
COPY public public/
|
WORKDIR /app
|
||||||
COPY types types/
|
COPY . .
|
||||||
|
COPY --from=deps /app/node_modules ./node_modules
|
||||||
|
|
||||||
ENV NEXT_TELEMETRY_DISABLED=1
|
ENV NEXT_TELEMETRY_DISABLED=1
|
||||||
ENV NEXT_PUBLIC_API_URL=https://api.sahkoinsinoorikilta.fi/api
|
ENV NEXT_PUBLIC_API_URL=https://api.sahkoinsinoorikilta.fi/api
|
||||||
ENV NEXT_PUBLIC_SITE_URL=https://sahkoinsinoorikilta.fi
|
ENV NEXT_PUBLIC_SITE_URL=https://sahkoinsinoorikilta.fi
|
||||||
RUN npm run build
|
RUN npm run build
|
||||||
|
|
||||||
FROM node:14-alpine as server
|
# Production image, copy all the files and run next
|
||||||
WORKDIR /www
|
FROM node:14-alpine AS runner
|
||||||
COPY package.json package-lock.json next.config.js next-sitemap.js ./
|
WORKDIR /app
|
||||||
COPY --from=builder .next .next
|
|
||||||
COPY --from=builder node_modules node_modules
|
ENV NODE_ENV production
|
||||||
COPY --from=builder public public
|
|
||||||
|
COPY --from=builder /app/next.config.js ./
|
||||||
|
COPY --from=builder /app/public ./public
|
||||||
|
COPY --from=builder /app/.next ./.next
|
||||||
|
COPY --from=builder /app/node_modules ./node_modules
|
||||||
|
COPY --from=builder /app/package.json ./package.json
|
||||||
|
|
||||||
RUN npm prune --production
|
RUN npm prune --production
|
||||||
|
|
||||||
|
RUN addgroup -g 1001 -S nodejs
|
||||||
|
RUN adduser -S nextjs -u 1001
|
||||||
|
RUN chown -R nextjs:nodejs /app/.next
|
||||||
|
USER nextjs
|
||||||
|
|
||||||
EXPOSE 3000
|
EXPOSE 3000
|
||||||
ENTRYPOINT ["npm", "run", "serve"]
|
|
||||||
|
CMD ["npm", "run", "serve"]
|
||||||
|
|||||||
Reference in New Issue
Block a user