forked from Seneca-CDOT/telescope
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDockerfile
57 lines (43 loc) · 1.86 KB
/
Dockerfile
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
# This Docker file is used for
# `development`, `test`, and `staging` enviornments
#
# CLI command to run this file: script="some-name" docker-compose up --build
# `some-name` is one of the names provided under `scripts` tag in `package.json` file
# example: $ script="test" docker-compose up --build --> will run telescope with `test` script
# default: $ docker-compose up --build --> will run telescope with `start` script
# Dockerfile
#
# -------------------------------------
# NEXT_PUBLIC_API_URL is needed by the next.js build, which we define
# as a build ARG in API_URL
# Context: Build Context
FROM node:lts-alpine as build
# Tini Entrypoint for Alpine
# util-linux required to optimize builds using multiple cores
RUN apk add --no-cache tini util-linux
ENTRYPOINT [ "/sbin/tini", "--"]
# Set Working Directory Context
WORKDIR "/telescope"
# Copy package.jsons for each service
COPY package.json .
# -------------------------------------
# Context: Dependencies
FROM build AS backend_dependencies
# Install Production Modules!
# Disable postinstall hook in this case since we are being explict with installs
# `postinstall` typically goes on to install front-end and autodeployment modules
# which though is logical for local development, breaks docker container caching trick.
RUN npm install --only=production --no-package-lock --ignore-scripts
# -------------------------------------
# Context: Release
FROM build AS release
# GET production code from previous containers
COPY --from=backend_dependencies /telescope/node_modules /telescope/node_modules
COPY ./src/backend ./src/backend
# Directory for log files
RUN mkdir /log
# Environment variable with default value
ENV script=start
# Running telescope when the image gets built using a script
# `script` is one of the scripts from `package.json`, passed to the image
CMD ["sh", "-c", "npm run ${script}"]