nodejs应用程序的Docker构建需要很长时间



使用docker build命令构建映像时,nodejs应用程序的构建时间很长。

需要几分钟的时间

08:03:15  Step 1/11 : FROM node:14.1.0-alpine AS build
08:03:15   ---> 0854fcfc1637
08:03:15  Step 2/11 : COPY server/package*.json /nodejs/server/
08:03:15   ---> Using cache
08:03:15   ---> 4996283ff991
08:03:15  Step 3/11 : WORKDIR /nodejs/server
08:03:15   ---> Using cache
08:03:15   ---> 93e5b63fa81d
08:03:15  Step 4/11 : RUN npm ci
08:03:15   ---> Using cache
08:03:15   ---> 2c825e02ea01
08:03:15  Step 5/11 : COPY server ./
08:03:15   ---> Using cache
08:03:15   ---> 69c024cde79f
08:03:15  Step 6/11 : WORKDIR /nodejs
08:03:15   ---> Using cache
08:03:15   ---> 49d7f8bd9514
08:03:15  Step 7/11 : COPY package*.json ./
08:03:16   ---> e82bee625c3e
08:03:16  Step 8/11 : RUN npm ci
08:03:16   ---> Running in ecfd57702906
...
08:03:49  added 1483 packages in 26.419s
08:09:40  Removing intermediate container ecfd57702906
...
08:09:40   ---> 7c6b67d85b0b
08:09:40  Step 9/11 : COPY *.json ./
08:09:43   ---> 0165efd1c97d
08:09:43  Step 10/11 : COPY src ./src/
08:09:51   ---> 42e54cee6b91
08:09:51  Step 11/11 : RUN npm run build:prod
08:09:51   ---> Running in af6f9b013d27

在构建Java映像时不会发生这种情况。

我的Dockerfile

FROM node:14.1.0-alpine AS build
COPY server/package*.json /nodejs/server/
WORKDIR /nodejs/server
RUN npm ci
COPY server ./
WORKDIR /nodejs
COPY package*.json ./
RUN npm ci
COPY *.json ./
COPY src ./src/
RUN npm run build:prod
...

我试着使用buildkit,但它有相同的行为

08:37:20  #17 exporting to image
08:37:20  #17 exporting layers
08:50:12  #17 exporting layers 766.8s done

我还将node_modules添加到了.dokerignore文件中,但没有任何更改。

Docker版本19.03.6,构建369ce74a3c

可能是什么问题?

"添加1483个包裹…"one_answers"移除中间容器"之间发生了什么?

我已经找到了问题的原因,如果有人遇到类似的问题,我想与大家分享。

较长的"导出层"时间是由其中一个层中的node_modules文件夹引起的。删除它解决了问题,但它实际上是一种变通方法。

我合并了npm-ci和npm-run构建。。。步骤,并在同一步骤中删除了nodemodule。

RUN npm ci && npm run build:prod && rm -rf node_modules

所以Dockerfile中的最后构建阶段看起来像这个

FROM node:14.1.0-alpine AS build
COPY server/package*.json /nodejs/server/
WORKDIR /nodejs/server
RUN npm ci
COPY server ./
WORKDIR /nodejs
COPY package*.json ./
COPY *.json ./
COPY src ./src/
RUN npm ci && npm run build:prod && rm -rf node_modules
...

正如我所说,这只是一个变通方法,我认为根本原因是Docker在导出带有大量小文件(如node_modules中的文件(的层时遇到了问题。

相关内容

最新更新