gpt4 book ai didi

docker - 大厅 CI : leverage docker image cache

转载 作者:IT老高 更新时间:2023-10-28 12:40:52 25 4
gpt4 key购买 nike

我完全理解 Concourse 是无状态的,但是有没有办法重用已经拉取的 docker 镜像?就我而言,我构建了大约 10 个具有相同基础镜像的 docker 镜像,但每次触发构建时,Concourse 都会拉取基础镜像 10 次。

是否可以使用标准 docker 资源提取该图像一次并在以后重新使用它(至少在同一构建范围内)?

是的,应该可以使用自定义图像并在 sh 脚本中对其进行编码,但我不喜欢邀请自行车。

如果标准 docker 资源不允许这样做,是否可以以某种方式扩展它以启用此类行为?

--cache-from 没有帮助,因为 CI 大部分时间都在提取图像,而不是构建新层。

最佳答案

理论

首先,一些 Concourse 理论(至少从 v3.3.1 开始):

人们经常谈论 Concourse 有一个“缓存”,但误解了它的含义。每个大厅工作人员在磁盘上都有一组卷,这些卷留在周围,形成一个卷缓存。此卷缓存包含已由资源 getput 以及任务 outputs 填充的卷。

人们也经常误解 docker-image-resource 如何使用 Docker。您的 Concourse 安装没有运行全局 docker 服务器,实际上 Concourse 容器不是 Docker 容器,它们是 runC 容器。每个 docker-image-resource 进程(checkgetput)都在其自己的 runC 容器中运行,其中有一个本地 docker 服务器正在运行。这意味着没有全局 docker 服务器正在拉取 docker 图像并缓存层以供进一步使用。

这意味着当我们谈论使用 docker-image-resource 进行缓存时,它意味着将图像加载或预拉到本地 docker 服务器中。


练习

现在是优化构建时间的选项:

load_base

背景

docker-image-resource put 中的 load_base 参数告诉资源首先 docker load图像(通过 get 检索)到其本地 docker 服务器,构建通过 put 参数指定的图像。

当您需要将图像预填充到“docker 缓存”中时,这很有用。在您的情况下,您可能希望预加载 FROM 指令中使用的图像。这更有效,因为它使用 Concourse 自己的卷缓存仅拉取“base”一次,使其在执行 FROM 命令期间可供 docker 服务器使用。

用法

您可以使用 load_base 如下:

假设你想构建一个自定义的 python 镜像,并且你有一个带有 ci/Dockerfile 文件的 git 存储库,如下所示:

FROM ubuntu

RUN apt-get update
RUN apt-get install -y python python-pip

如果您想在利用 Concourse 卷缓存 以及 Docker 镜像层缓存 的同时自动构建/推送此镜像:

resources:
- name: ubuntu
type: docker-image
source:
repository: ubuntu

- name: python-image
type: docker-image
source:
repository: mydocker/python

- name: repo
type: git
source:
uri: ...

jobs:
- name: build-image-from-base
plan:
- get: repo
- get: ubuntu
params: {save: true}
- put: python-image
params:
load_base: ubuntu
dockerfile: repo/ci/Dockerfile

cache & cache_tag

背景

docker-image-resource put 中的 cachecache_tag 参数告诉资源首先 < em>从你的远程源中拉一个特定的图像+标签,构建通过你的 put 参数指定的图像。

当下拉图像比从头构建图像更容易时,这很有用,例如您的构建过程非常漫长,例如昂贵的编译

利用了 Concourse 的卷缓存,并利用了 Docker 的 --cache-from 功能(这有可能需要先执行 docker pull ) 在每次 put 期间。

用法

您可以使用 cachecache_tag 如下:

假设你想构建一个自定义的 ruby​​ 镜像,你从源代码编译 ruby​​,并且你有一个带有 ci/Dockerfile 文件的 git 存储库,如下所示:

FROM ubuntu

# Install Ruby
RUN mkdir /tmp/ruby;\
cd /tmp/ruby;\
curl ftp://ftp.ruby-lang.org/pub/ruby/2.0/ruby-2.0.0-p247.tar.gz | tar xz;\
cd ruby-2.0.0-p247;\
chmod +x configure;\
./configure --disable-install-rdoc;\
make;\
make install;\
gem install bundler --no-ri --no-rdoc

RUN gem install nokogiri

如果您想自动构建/推送此镜像,同时仅利用 Docker 镜像层缓存:

resources: 
- name: compiled-ruby-image
type: docker-image
source:
repository: mydocker/ruby
tag: 2.0.0-compiled

- name: repo
type: git
source:
uri: ...

jobs:
- name: build-image-from-cache
plan:
- get: repo
- put: compiled-ruby-image
params:
dockerfile: repo/ci/Dockerfile
cache: mydocker/ruby
cache_tag: 2.0.0-compiled

推荐

如果你想提高构建 docker 镜像的效率,我个人认为 load_base 应该在大多数情况下使用。因为它使用资源 get,它利用了 Concourse 卷缓存,并且避免了需要做额外的 docker pulls。

关于docker - 大厅 CI : leverage docker image cache,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44475165/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com