1

由于我的代码(nodeJS-application)比(npm)依赖项更频繁地更改,我试图在我的 CI 中构建类似缓存的东西。

我正在使用多阶段 Dockerfile。在那我运行 npm install 为所有,而且只有,prod 依赖项。后来它们被复制到最终图像中,使其更小。伟大的。

如果没有更改依赖项,构建也会变得非常快。

然而,随着时间的推移,高清已经满了,所以我必须跑去docker prune ...拿回空间。但是,当我这样做时,缓存就消失了。

因此,如果我prune在 CI 中的每个管道之后运行一个,我不会获得多阶段 Dockerfile 的“缓存功能”。

### 1. Build
FROM node:10.13 AS build
WORKDIR /home/node/app

COPY ./package*.json ./
COPY ./.babelrc ./

RUN npm set progress=false \
    && npm config set depth 0 \
    && npm install --only=production --silent \
    && cp -R node_modules prod_node_modules
RUN npm install --silent

COPY ./src ./src
RUN ./node_modules/.bin/babel ./src/ -d ./dist/ --copy-files

### 2. Run
FROM node:10.13-alpine
RUN apk --no-cache add --virtual \
      builds-deps \
      build-base \
      python
WORKDIR /home/node/app

COPY --from=build /home/node/app/prod_node_modules ./node_modules
COPY --from=build /home/node/app/dist .

EXPOSE 3000
ENV NODE_ENV production
CMD ["node", "app.js"]
4

1 回答 1

1

如果您的 CI 系统允许您执行多个docker build步骤,则可以将其拆分为两个 Dockerfile。

# Dockerfile.dependencies
# docker build -f Dockerfile.dependencies -t me/dependencies .
FROM node:10.13
...
RUN npm install
# Dockerfile
# docker build -t me/application .
FROM me/dependencies:latest AS build
COPY ./src ./src
RUN ./node_modules/.bin/babel ./src/ -d ./dist/ --copy-files

FROM node:10.13-alpine
...
CMD ["node", "app.js"]

如果这样做,则可以在每次构建后删除未使用的图像:

docker image prune

最新版本的依赖图像将有一个标签,因此它不会“悬空”,也不会出现在图像列表中。在每个构建中,它的标签将“取自”前一个构建(如果它改变了),因此这个序列将清理以前的构建。这也将删除“构建”图像,尽管您注意到如果有任何更改以触发构建,它可能会在src树中,因此强制重建是合理的。

在这种特定情况下,只使用latest标签是合适的。如果最终构建的图像有一些更独特的标签(例如,基于版本号或时间戳)并且它们正在堆积,那么您可能需要对该图像列表进行一些更有创意的过滤以清理它们。

于 2018-11-11T11:42:30.487 回答