docker - 防止 docker 在更改代码后从头开始构建镜像

标签 docker docker-build

一个docker新手,尝试在docker容器中开发;我有一个问题,每次我对代码进行单行更改并尝试重新运行容器时,docker 都会从头开始重建图像,这需要很长时间;我应该如何正确设置项目以便充分利用 cache?可以肯定的是,只要我对源代码进行一些更改,它就不必重新安装所有 apt-getpip installs(顺便说一句,我正在使用 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 在更改代码后从头开始构建镜像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46814242/

相关文章:

docker - 在docker中创建/tmp目录

docker - 从 pod 内部访问 Kubernetes pod 的日志文件?

mysql - 带有自定义主题+ mysql的Docker-compose wordpress

docker - 如何将elasticsearch模板与docker镜像捆绑在一起?

docker - 为什么不能访问grafana服务的静态文件?

docker - 如何在 GitLab CI 作业中使用 docker 构建缓存

docker - 从多阶段 Docker 构建中提取文件

linux - 为什么 Docker COPY 不会更改文件权限? (--chmod)

docker - Docker 镜像上的 pip 找不到 Rust - 即使安装了 Rust

Docker容器-向其中注入(inject)敏感数据的最佳实践是什么