构建更小的容器镜像的技巧

系统 Linux
Linux 容器已经成为一个热门话题,保证容器镜像较小被认为是一个好习惯。本文提供了有关如何构建较小 Fedora 容器镜像的一些技巧。

[[266174]]

Linux 容器已经成为一个热门话题,保证容器镜像较小被认为是一个好习惯。本文提供了有关如何构建较小 Fedora 容器镜像的一些技巧。

microdnf

Fedora 的 DNF 是用 Python 编写的,因为它有各种各样的插件,因此它的设计是可扩展的。但是 有一个 Fedora 基本容器镜像替代品,它使用一个较小的名为 microdnf 的包管理器,使用 C 编写。要在 Dockerfile 中使用这个最小的镜像,FROM 行应该如下所示:

  1. FROM registry.fedoraproject.org/fedora-minimal:30

如果你的镜像不需要像 Python 这样的典型 DNF 依赖项,例如,如果你在制作 NodeJS 镜像时,那么这是一个重要的节省项。

在一个层中安装和清理

为了节省空间,使用 dnf clean all 或其 microdnf 等效的 microdnf clean all 删除仓库元数据非常重要。但是你不应该分两步执行此操作,因为这实际上会将这些文件保存在容器镜像中,然后在另一层中将其标记为删除。要正确地执行此操作,你应该像这样一步完成安装和清理:

  1. FROM registry.fedoraproject.org/fedora-minimal:30
  2. RUN microdnf install nodejs && microdnf clean all

使用 microdnf 进行模块化

模块化是一种给你选择不同堆栈版本的方法。例如,你可能需要在项目中用非 LTS 的 NodeJS v11,旧的 LTS NodeJS v8 用于另一个,***的 LTS NodeJS v10 用于另一个。你可以使用冒号指定流。

  1. # dnf module list
  2. # dnf module install nodejs:8

dnf module install 命令意味着两个命令,一个启用流,另一个是从它安装 nodejs。

  1. # dnf module enable nodejs:8
  2. # dnf install nodejs

尽管 microdnf 不提供与模块化相关的任何命令,但是可以启用带有配置文件的模块,并且 libdnf(被 microdnf 使用)似乎支持模块化流。该文件看起来像这样:

  1. /etc/dnf/modules.d/nodejs.module
  2. [nodejs]
  3. name=nodejs
  4. stream=8
  5. profiles=
  6. state=enabled

使用模块化的 microdnf 的完整 Dockerfile 如下所示:

  1. FROM registry.fedoraproject.org/fedora-minimal:30
  2. RUN \
  3. echo -e "[nodejs]\nname=nodejs\nstream=8\nprofiles=\nstate=enabled\n" > /etc/dnf/modules.d/nodejs.module && \
  4. microdnf install nodejs zopfli findutils busybox && \
  5. microdnf clean all

多阶段构建

在许多情况下,你可能需要大量的无需用于运行软件的构建时依赖项,例如构建一个静态链接依赖项的 Go 二进制文件。多阶段构建是分离应用构建和应用运行时的有效方法。

例如,下面的 Dockerfile 构建了一个 Go 应用 confd

  1. # building container
  2. FROM registry.fedoraproject.org/fedora-minimal AS build
  3. RUN mkdir /go && microdnf install golang && microdnf clean all
  4. WORKDIR /go
  5. RUN export GOPATH=/go; CGO_ENABLED=0 go get github.com/kelseyhightower/confd
  6.  
  7. FROM registry.fedoraproject.org/fedora-minimal
  8. WORKDIR /
  9. COPY --from=build /go/bin/confd /usr/local/bin
  10. CMD ["confd"]

通过在 FROM 指令之后添加 AS 并从基本容器镜像中添加另一个 FROM 然后使用 COPY --from= 指令将内容从构建的容器复制到第二个容器来完成多阶段构建。

可以使用 podman 构建并运行此 Dockerfile:

  1. $ podman build -t myconfd .
  2. $ podman run -it myconfd

 

责任编辑:庞桂玉 来源: Linux中国
相关推荐

2021-05-13 09:07:03

容器云环境镜像

2019-03-28 10:20:09

容器镜像系统运维Linux

2019-09-10 13:34:30

Linux操作系统软件

2022-07-15 14:54:00

DockerLinux技巧

2019-05-24 13:30:57

PiShrink树莓派Linux

2019-10-30 12:00:02

Ansible容器与云容器镜像

2017-06-13 14:43:27

容器数据镜像系统

2021-08-30 06:27:21

工具容器Docker

2023-11-03 13:20:13

Kubernetes

2024-03-20 13:11:45

DockerLinux

2019-07-16 14:44:52

DockerMySQL操作系统

2017-11-13 17:17:11

Docker镜像Go

2021-05-08 16:11:08

Java开发代码

2023-11-03 15:33:22

Docker镜像云计算

2010-01-06 15:18:51

Json插件

2023-10-30 11:01:37

Buildpack云原生

2023-01-29 07:45:06

DevOps

2020-11-23 18:39:54

容器Kubernetes架构

2020-05-20 12:30:44

容器Linux系统

2024-08-27 12:21:52

桌面应用开发Python
点赞
收藏

51CTO技术栈公众号