0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

新一代更强大的镜像构建工具Earthly

马哥Linux运维 来源:马哥Linux运维 2023-03-30 11:21 次阅读
一、Earthly 介绍

开局一张图,功能全靠吹。

dfcaa480-ce59-11ed-bfe3-dac502259ad0.png

Earthly 是一个更加高级的 Docker 镜像构建工具,Earthly 通过自己定义的 Earthfile 来代替传统的 Dockerfile 完成镜像构建;Earthfile 就如同 Earthly 官方所描述:

Makefile + Dockerfile = Earthfile

在使用 Earthly 进行构建镜像时目前强依赖于 buildkit,Earthly 通过 buildkit 支持了一些 Dockerfile 的扩展语法,同时将 Dockerfile 与 Makefile 整合,使得多平台构建和代码化 Dockerfile 变得更加简单;使用 Earthly 可以更加方便的完成 Dockerfile 的代码复用以及更加友好的 CI 自动集成。

二、快速开始

2.1、安装依赖

Earthly 目前依赖于 Docker 和 Git,所以安装 Earthly 前请确保机器已经安装了 Docker 和 Git。

2.2、安装 Earthly

Earthly 采用 Go 编写,所以主要就一个二进制文件,Linux 下安装可以直接参考官方的安装脚本:

$ sudo /bin/sh -c 'wget https://github.com/earthly/earthly/releases/latest/download/earthly-linux-amd64 -O /usr/local/bin/earthly && chmod +x /usr/local/bin/earthly && /usr/local/bin/earthly bootstrap --with-autocomplete'

安装完成后 Earthly 将会启动一个 buildkitd 容器: earthly-buildkitd。

2.3、语法高亮

目前 Earthly 官方支持 VS Code、VIM 以及 Sublime Text 三种编辑器的语法高亮,具体如何安装请参考 官方文档[1]。

2.4、基本使用

本示例源于官方 Basic 教程,以下示例以编译 Go 项目为样例:

首先创建一个任意名称的目录,目录中存在项目源码文件以及一个 Earthfile 文件;

main.go

packagemain

import"fmt"

funcmain(){
fmt.Println("helloworld")
}

Earthfile

FROMgolang:1.17-alpine
WORKDIR/go-example

build:
COPYmain.go.
RUNgobuild-obuild/go-examplemain.go
SAVEARTIFACTbuild/go-example/go-exampleASLOCALbuild/go-example

docker:
COPY+build/go-example.
ENTRYPOINT["/go-example/go-example"]
SAVEIMAGEgo-example:latest

有了 Earthfile 以后我们就可以使用 Earthly 将其打包为镜像;

#目录结构
~/t/earthlytest❯❯❯tree
.
├──Earthfile
└──main.go

0directories,2files

#通过earthly进行构建
~/t/earthlytest❯❯❯earthly+docker

dff2a75a-ce59-11ed-bfe3-dac502259ad0.png

构建完成后我们就可以直接从 docker 的 images 列表中查看刚刚构建的镜像,并运行:

e03608a6-ce59-11ed-bfe3-dac502259ad0.png

三、进阶使用

3.1、多阶段构建

Earthfile 中包含类似 Makefile 一样的 target,不同的 target 之间还可以通过特定语法进行引用,每个 target 都可以被单独执行,执行过程中 earthly 会自动解析这些依赖关系。

这种多阶段构建时语法很弹性,我们可以在每个阶段运行独立的命令以及使用不同的基础镜像;从快速开始中可以看到,我们始终使用了一个基础镜像(golang:1.17-alpine),对于 Go 这种编译后自带运行时不依赖其语言 SDK 的应用,我们事实上可以将 “发布物” 仅放在简单的运行时系统镜像内,从而减少最终镜像体积:

e066d7c4-ce59-11ed-bfe3-dac502259ad0.png

由于使用了多个 target,所以我们可以单独的运行 build 这个 target 来验证我们的编译流程,这种多 target 的设计方便我们构建应用时对编译、打包步骤的细化拆分,同时也方便我们进行单独的验证。例如我们单独执行 build 这个 target 来验证我们的编译流程是否正确:

e098bab4-ce59-11ed-bfe3-dac502259ad0.png

在其他阶段验证完成后,我们可以直接运行最终的 target,earthly 会自动识别到这种依赖关系从而自动运行其依赖的 target:

e0e47788-ce59-11ed-bfe3-dac502259ad0.png

3.2、扩展指令

3.2.1、SAVE

SAVE 指令是 Earthly 自己的一个扩展指令,实际上分为 SAVE ARTIFACT 和 SAVE IMAGE;其中 SAVE ARTIFACT 指令格式如下:

SAVEARTIFACT[--keep-ts][--keep-own][--if-exists][--force][][ASLOCAL<local-path>]

SAVE ARTIFACT 指令用于将文件或目录从 build 运行时环境保存到 target 的 artifact 环境;当保存到 artifact 环境后,可以通过 COPY 等命令在其他位置进行引用,类似于 Dockerfile 的 COPY --from... 语法;不同的是 SAVE ARTIFACT 支持 AS LOCAL附加参数,一但指定此参数后,earthly 会同时将文件或目录在宿主机复制一份,一般用于调试等目的。SAVE ARTIFACT 命令在上面的样例中已经展示了,在运行完 earthly +build 命令后实际上会在本地看到被 SAVE 出来的 ARTIFACT:

e12cb688-ce59-11ed-bfe3-dac502259ad0.png

而另一个 SAVE IMAGE 指令则主要用于将当前的 build 环境 SAVE 为一个 IMAGE,如果指定了 --push 选项,同时在执行 earthly +target 命令时也加入 --push 选项,该镜像将会自动被推送到目标 Registry 上。SAVE IMAGE 指令格式如下:

SAVEIMAGE[--cache-from=][--push]...

e166a758-ce59-11ed-bfe3-dac502259ad0.png

3.2.2、GIT CLONE

GIT CLONE 指令用于将指定 git 仓库 clone 到 build 环境中;与 RUN git clone... 命令不同的是,GIT CLONE 通过宿主机的 git 命令运行,它不依赖于容器内的 git 命令,同时还可以直接为 earthly 配置 git 认证,从而避免将这些安全信息泄漏到 build 环境中;关于如何配置 earthly 的 git 认证请参考 官方文档[2];下面是 GIT CLONE 指令的样例:

e1c2b14c-ce59-11ed-bfe3-dac502259ad0.png

3.2.3、COPY

COPY 指令与标准的 Dockerfile COPY 指令类似,除了支持 Dockerfile 标准的 COPY 功能以外,earthly 中的 COPY 指令可以引用其他 target 环节产生的 artifact,在引用时会自动声明依赖关系;即当在 B target 中存在 COPY +A/xxxxx /path/to/copy 类似的指令时,如果只单纯的执行 earthly +B,那么 earthly 根据依赖分析会得出在 COPY 之前需要执行 target A。COPY 指令的语法格式如下:

#与Dockerfile相同的使用方式,从上下文复制
COPY[options...]...

#扩展支持的从target复制方式
COPY[options...]...

3.2.4、RUN

RUN 指令在标准使用上与 Dockerfile 里保持一致,除此之外增加了更多的扩展选项,其指令格式如下:

#shell方式运行(/bin/sh-c)
RUN[--push][--entrypoint][--privileged][--secret=][--ssh][--mount][--]<command>

#exec方式运行
RUN[[...],"","","",...]

其中 --privileged 选项允许运行的命令使用 privileged capabilities,但是需要 earthly 在运行 target 时增加 --allow-privileged 选项;--interactive / --interactive-keep 选项用于交互式执行一些命令,在完成交互后 build 继续进行,在交互过程中进行的操作都会被持久化到 镜像中:

e218afde-ce59-11ed-bfe3-dac502259ad0.png

限于篇幅原因,其他的具体指令请查阅官方文档 Earthfile reference[3]。

3.3、UDCS

UDCs 全称 “User-defined commands”,即用户定义指令;通过 UDCs 我们可以将 Earthfile 中特定的命令剥离出来,从而实现更加通用和统一的代码复用;下面是一个定义 UDCs 指令的样例:

#定义一个Command
#注意:语法必须满足以下规则
#1、名称全大写
#2、名称下划线分割
#3、首个命令必须为COMMAND(后面没有冒号)
MY_COPY:
COMMAND
ARGsrc
ARGdest=./
ARGrecursive=false
RUNcp$(if$recursive="true";thenprintf---r;fi)"$src""$dest"

#target中引用
build:
FROMalpine:3.13
WORKDIR/udc-example
RUNecho"hello">./foo
#通过DO关键字引用UDCs
DO+MY_COPY--src=./foo--dest=./bar
RUNcat./bar#prints"hello"

UDCs 不光可以定义在一个 Earthfile 中,UDCs 可以跨文件、跨目录引用:

e26ed74c-ce59-11ed-bfe3-dac502259ad0.png

有了 UDCs 以后,我们可以通过这种方式将对基础镜像的版本统一控制、对特殊镜像的通用处理等操作全部抽象出来,然后每个 Earthfile 根据需要进行引用;关于 UDCs 的使用样例可以参考我的 autobuild[4] 项目,其中的 udcs[5] 目录定义了大量的通用 UDCs,这些 UDCs 被其他目标镜的 Earthfile 批量引用。

3.4、多平台构建

在以前使用 Dockerfile 的时候,我们需要自己配置然后开启 buildkit 来实现多平台构建;在配置过程中可能会很繁琐,现在使用 earthly 可以默认帮我们实现多平台的交叉编译,我们需要做的仅仅是在 Earthfile 中声明需要支持哪些平台而已:

e2d3975e-ce59-11ed-bfe3-dac502259ad0.png

以上 Earthfile 在执行 earthly --push +all 构建时,将会自动构建四个平台的镜像,并保持单个 tag,同时由于使用了 --push 选项还会自动推送到 Docker Hub 上:

e2f7ad10-ce59-11ed-bfe3-dac502259ad0.png

四、总结

Earthly 弥补了 Dockerfile 的很多不足,解决了很多痛点问题;但同样可能需要一些学习成本,但是如果已经熟悉了 Dockerfile 其实学习成本不高;所以目前还是比较推荐将 Dockerfile 切换为 Earthfile 进行统一和版本化管理的。本文由于篇幅所限(懒)很多地方没有讲,比如共享缓存等,所以关于 Earthly 更多的详细使用等最好还是仔细阅读一下官方文档[6]。

审核编辑 :李倩



声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 编辑器
    +关注

    关注

    1

    文章

    800

    浏览量

    31109
  • 语法
    +关注

    关注

    0

    文章

    44

    浏览量

    9779
  • Docker
    +关注

    关注

    0

    文章

    454

    浏览量

    11807

原文标题:新一代更强大的镜像构建工具 Earthly

文章出处:【微信号:magedu-Linux,微信公众号:马哥Linux运维】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    AMD谈新一代Zen处理器:更高的IPC,更强超频能力

    问题。AMD桌面CPU市场总监Don Woligroski在接受Joker Production的采访中表示,将来的Zen架构处理器会有更高的IPC和更强的超频能力。  AMD谈新一代Zen处理器:更高
    发表于 09-07 09:43

    新一代纳秒级高带宽仿真工具平台HAC Express的优势

    新一代纳秒级高带宽仿真工具平台——HAC Express
    发表于 01-11 06:47

    常用根文件系统构建工具有哪些

    11、/mnt目录12、/tmp目录二、常用根文件系统构建工具简介1、BusyBox工具2、Buildroot工具3、Yocto工具、简介
    发表于 11-05 07:28

    RT-Thread系统中的Scons构建工具资料推荐

    1 构建工具(系统)1.1 什么是构建工具(系统)构建工具 (software construction tool) 是种软件,它可以根据
    发表于 05-07 15:35

    介绍款非常方便的java领域docker镜像构建工具

    前言本文主要介绍的是google开源的个java领域的docker构建工具jib.目前在github上的start有8.5k,fork有784,是款非常方便的java领域docker构建工
    发表于 07-19 17:41

    RVCT 3.0 SP1构建工具-错误和警告

    RVCT 1.2,请参考“ADS 1.2构建工具-错误和警告”文档。 如果您使用的是RVCT的早期版本,那么可以将此作为第个参考来源,但“RVCT2.0构建工具-错误和警告”也可能有用。
    发表于 08-16 06:30

    面向Eclips的Nios II软件构建工具手册

    面向Eclips的Nios II软件构建工具手册 The Nios II Software Build Tools (SBT) for Eclipse is a set of plugins
    发表于 10-17 15:43 37次下载

    使用Nios II软件构建工具

    使用Nios II软件构建工具 This chapter describes the Nios II Software Build Tools (SBT), a set of utilities
    发表于 10-17 15:49 20次下载

    Nios II软件构建工具入门

    Nios II软件构建工具入门 The Nios II Software Build Tools (SBT) allows you to construct a wide variety
    发表于 10-17 15:51 29次下载

    2022 RT-Thread全球技术大会:RT-Thread的常见构建工具

    RT-Thread的常见构建工具主要有以下图中的几种,同时介绍了相关特点
    的头像 发表于 05-27 14:39 847次阅读
    2022 RT-Thread全球技术大会:RT-Thread的常见<b class='flag-5'>构建工具</b>

    跨平台构建工具xmake简介与安装使用说明

    大家好,我是ZhengN。本次给大家分享个优秀的跨平台构建工具
    的头像 发表于 07-19 15:52 5791次阅读

    镜像构建Dockerfile的介绍

    Dockerfile 是个用来构建镜像的文本文件,文本内容包含了条条构建镜像所需的指令和说明
    的头像 发表于 09-06 09:36 1104次阅读

    推荐款现代高效的java构建工具

    相信使用Java的同学都用过Maven,这是个非常经典好用的项目构建工具
    的头像 发表于 02-24 11:22 676次阅读

    RT-Thread CMake构建工具

    RT Thread原生使用的构建工具是SCons,编译工具链使用官方提供的env工具,内含多种嵌入式常用的编译环境和脚本,可以算得上环境万能百宝箱。
    的头像 发表于 10-12 17:06 638次阅读
    RT-Thread CMake<b class='flag-5'>构建工具</b>

    手动构建Docker镜像的方法

    不推荐使用docker commit命令,而应该使用更灵活、更强大的dockerfile来构建docker镜像
    的头像 发表于 08-05 15:30 445次阅读
    手动<b class='flag-5'>构建</b>Docker<b class='flag-5'>镜像</b>的方法