防止 docker 在更改代码后从头开始构建图像
Prevent docker from building the image from scratch after making changes to the code
一个docker新手,尝试在docker容器中开发;我有一个问题,就是每次我更改一行代码并尝试重新运行容器时,docker 将从头开始重建图像,这需要很长时间;我应该如何正确设置项目以充分利用 cache?很确定它不必在我对源代码进行一些更改时重新安装所有 apt-get
和 pip install
(顺便说一句,我正在 python 中开发)。任何人都知道我错过了什么。感谢任何帮助。
我当前的 docker 文件:
FROM tiangolo/uwsgi-nginx-flask:python3.6
# Copy the current directory contents into the container at /app
ADD ./app /app
# Run python's package manager and install the flask package
RUN apt-get update -y \
&& apt-get -y install default-jre \
&& apt-get install -y \
build-essential \
gfortran \
libblas-dev \
liblapack-dev \
libxft-dev \
&& rm -rf /var/lib/apt/lists/*
WORKDIR /app
ADD ./requirements.txt /app/requirements.txt
RUN pip3 install -r requirements.txt
一旦 Dockerfile 中的缓存中断,以下所有行都需要重建,因为它们不再有缓存命中。缓存搜索查找现有的前一层和相同的命令(或类似 COPY
的内容)以重用缓存。如果两者不匹配,则说明缓存未命中,它会执行构建步骤。对于您的场景,您只需要重新排序您的行以确保经常更改的部分位于文件的末尾而不是文件的开头:
FROM tiangolo/uwsgi-nginx-flask:python3.6
# Run python's package manager and install the flask package
RUN apt-get update -y \
&& apt-get -y install default-jre \
&& apt-get install -y \
build-essential \
gfortran \
libblas-dev \
liblapack-dev \
libxft-dev \
&& rm -rf /var/lib/apt/lists/*
WORKDIR /app
COPY requirements.txt /app/requirements.txt
RUN pip3 install -r requirements.txt
# Copy the current directory contents into the container at /app
COPY app /app
我还将你的 ADD
行修改为 COPY
因为你不需要 ADD
.
提供的额外功能
在开发过程中,我建议将应用作为一个卷安装在您的容器中,这样您就不需要为每次代码更改都重建映像。您可以将 COPY app /app
保留在您的 Dockerfile 中,卷安装将简单地覆盖目录,在该位置隐藏图像中的任何内容。您只需要重新启动容器即可获取您的修改。完成后,构建将创建一个看起来与您的开发环境相同的图像。
一个docker新手,尝试在docker容器中开发;我有一个问题,就是每次我更改一行代码并尝试重新运行容器时,docker 将从头开始重建图像,这需要很长时间;我应该如何正确设置项目以充分利用 cache?很确定它不必在我对源代码进行一些更改时重新安装所有 apt-get
和 pip install
(顺便说一句,我正在 python 中开发)。任何人都知道我错过了什么。感谢任何帮助。
我当前的 docker 文件:
FROM tiangolo/uwsgi-nginx-flask:python3.6
# Copy the current directory contents into the container at /app
ADD ./app /app
# Run python's package manager and install the flask package
RUN apt-get update -y \
&& apt-get -y install default-jre \
&& apt-get install -y \
build-essential \
gfortran \
libblas-dev \
liblapack-dev \
libxft-dev \
&& rm -rf /var/lib/apt/lists/*
WORKDIR /app
ADD ./requirements.txt /app/requirements.txt
RUN pip3 install -r requirements.txt
一旦 Dockerfile 中的缓存中断,以下所有行都需要重建,因为它们不再有缓存命中。缓存搜索查找现有的前一层和相同的命令(或类似 COPY
的内容)以重用缓存。如果两者不匹配,则说明缓存未命中,它会执行构建步骤。对于您的场景,您只需要重新排序您的行以确保经常更改的部分位于文件的末尾而不是文件的开头:
FROM tiangolo/uwsgi-nginx-flask:python3.6
# Run python's package manager and install the flask package
RUN apt-get update -y \
&& apt-get -y install default-jre \
&& apt-get install -y \
build-essential \
gfortran \
libblas-dev \
liblapack-dev \
libxft-dev \
&& rm -rf /var/lib/apt/lists/*
WORKDIR /app
COPY requirements.txt /app/requirements.txt
RUN pip3 install -r requirements.txt
# Copy the current directory contents into the container at /app
COPY app /app
我还将你的 ADD
行修改为 COPY
因为你不需要 ADD
.
在开发过程中,我建议将应用作为一个卷安装在您的容器中,这样您就不需要为每次代码更改都重建映像。您可以将 COPY app /app
保留在您的 Dockerfile 中,卷安装将简单地覆盖目录,在该位置隐藏图像中的任何内容。您只需要重新启动容器即可获取您的修改。完成后,构建将创建一个看起来与您的开发环境相同的图像。