Как мне запустить TypeScript `tsc` до` COPY` в Dockerfile.template? - PullRequest
0 голосов
/ 29 марта 2020

У меня есть рабочее решение для создания приложения TypeScript Node при развертывании на docker через файл Dockerfile.template:

Я бы предпочел запустить tsc перед копированием файлов в каталог приложения. Кроме того, работает npm i --production, чтобы у меня не было зависимостей dev в приложении. Это, похоже, не работает после npm i -g typescript (до КОПИРОВАНИЯ), без команды, которая будет найдена. Какой лучший способ продолжить?

Обновление с помощью решения

С помощью

выбранного решения , вот обновленный сценарий, который работает для следующего человека, который ищет это:
###################################
# First Stage: Compile TypeScript #
###################################

# Thanks: https://stackoverflow.com/questions/60916271/how-do-i-run-typescript-tsc-before-copy-in-dockerfile-template/60917273#60917273
FROM balenalib/%%BALENA_MACHINE_NAME%%-node AS build

# Install needed packages to build raspicam Node dependencies.
RUN install_packages build-essential libraspberrypi-bin

WORKDIR /usr/src/app

# Install the Javascript dependencies, including all devDependencies.
COPY package.json .
RUN npm i

# Copy the rest of the application in and build it.
COPY . ./

# RUN TypeScript build
RUN ./node_modules/typescript/bin/tsc -p ./tsconfig.json

# Clean up node_modules to not include dev dependencies.
RUN rm -rf ./node_modules
RUN JOBS=MAX npm i --production

##################################
# Second Stage: Prepare Dist App #
##################################

FROM balenalib/%%BALENA_MACHINE_NAME%%-node

# Defines our working directory in container
WORKDIR /usr/src/app

# Install packages
RUN install_packages build-essential libraspberrypi-bin

# This will copy all files in our root to the working directory in the container
COPY --from=build /usr/src/app/dist dist
COPY package.json package.json

# server.js will run when container starts up on the device
CMD ["npm", "run", "serve"]

Ответы [ 2 ]

2 голосов
/ 29 марта 2020

Для этого вы можете использовать многоступенчатую сборку . Первый этап включает в себя все зависимости разработки, в том числе tsc; второй этап включает в себя только файлы, необходимые для запуска встроенного приложения.

(я не знаком со спецификой используемой вами среды сборки c, так что это будет соответствовать стандарту node изображение.)

# First stage: compile things.
FROM node:12 AS build
WORKDIR /usr/src/app

# (Install OS dependencies; include -dev packages if needed.)

# Install the Javascript dependencies, including all devDependencies.
COPY package.json .
RUN npm install

# Copy the rest of the application in and build it.
COPY . .
# RUN npm build
RUN npx tsc -p ./tsconfig.json

# Now /usr/src/app/dist has the built files.

# Second stage: run things.
FROM node:12
WORKDIR /usr/src/app

# (Install OS dependencies; just libraries.)

# Install the Javascript dependencies, only runtime libraries.
COPY package.json .
RUN npm install --production

# Copy the dist tree from the first stage.
COPY --from=build /usr/src/app/dist dist

# Run the built application when the container starts.
EXPOSE 3000
CMD ["npm", "run", "serve"]
0 голосов
/ 29 марта 2020

Обычно вы компилируете свой TypeScript в JavaScript вне контейнера, а затем просто копируете полученный JavaScript в контейнер, например,

COPY dist ./

Где dist - это папка с скомпилированным JavaScript

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...