forked from ducktors/turborepo-remote-cache
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDockerfile
More file actions
63 lines (48 loc) · 1.82 KB
/
Dockerfile
File metadata and controls
63 lines (48 loc) · 1.82 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
FROM --platform=linux/amd64 node:16.17.1-alpine3.16@sha256:4e36c3dee7c32cef5bfce5bc1b5013d1c3cc542cfdefde2a545ec641e7c94243 as build
# set app basepath
ENV HOME=/home/app
# add app dependencies
COPY package.json $HOME/node/
COPY package-lock.json $HOME/node/
# change workgin dir and install deps in quiet mode
WORKDIR $HOME/node
RUN npm ci -q
# copy all app files
COPY . $HOME/node/
# compile typescript and build all production stuff
RUN npm run build
# remove dev dependencies and files that are not needed in production
RUN rm -rf node_modules
RUN npm install --omit=dev --ignore-scripts
# start new image for lower size
FROM --platform=linux/amd64 node:16.17.1-alpine3.16@sha256:4e36c3dee7c32cef5bfce5bc1b5013d1c3cc542cfdefde2a545ec641e7c94243
# dumb-init registers signal handlers for every signal that can be caught
RUN apk update && apk add --no-cache dumb-init
# create use with no permissions
RUN addgroup -g 101 -S app && adduser -u 100 -S -G app -s /bin/false app
# set app basepath
ENV HOME=/home/app
# copy production complied node app to the new image
COPY --chown=app:app --from=build $HOME/node/ $HOME/node/
# run app with low permissions level user
USER app
WORKDIR $HOME/node
EXPOSE 3000
ENV NODE_ENV=production
ENV TURBO_TOKEN=$TURBO_TOKEN
ENV BODY_LIMIT=$BODY_LIMIT
ENV STORAGE_PATH_USE_TMP_FOLDER=$STORAGE_PATH_USE_TMP_FOLDER
ENV STORAGE_PROVIDER=$STORAGE_PROVIDER
ENV STORAGE_PATH=$STORAGE_PATH
ENV AWS_ACCESS_KEY_ID=$AWS_ACCESS_KEY_ID
ENV AWS_SECRET_ACCESS_KEY=$AWS_SECRET_ACCESS_KEY
ENV AWS_REGION=$AWS_REGION
ENV S3_ACCESS_KEY=$S3_ACCESS_KEY
ENV S3_SECRET_KEY=$S3_SECRET_KEY
ENV S3_REGION=$S3_REGION
ENV S3_ENDPOINT=$S3_ENDPOINT
ENV GCS_PROJECT_ID=$GCS_PROJECT_ID
ENV GCS_CLIENT_EMAIL=$GCS_CLIENT_EMAIL
ENV GCS_PRIVATE_KEY=$GCS_PRIVATE_KEY
ENTRYPOINT ["dumb-init"]
CMD ["node", "--enable-source-maps", "build/index.js"]