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

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

3天内不再提示

Podman中运用容器存储库实用教程

马哥Linux运维 来源:稀土掘金 2024-03-05 14:32 次阅读

对于使用容器的用户来说,容器如何存储在磁盘上通常是一个谜。在这篇文章中,我们将了解容器镜像的存储方式以及可用于直接处理这些镜像的一些工具 - Podman

容器镜像存储的演变

当我第一次开始使用容器时,我不喜欢 Docker 架构的一件事是守护进程隐藏了有关镜像存储的信息。人们使用镜像的唯一现实方式是通过守护进程。我们正在开发该atomic工具,并希望有一种方法来挂载容器镜像,以便我们可以扫描它们。毕竟,容器镜像只是 devicemapper 或覆盖层下的挂载点。

Red Hat 的容器运行时团队创建了atomic mount在 Docker 下挂载镜像的命令,并在atomic scan.这里的问题是守护进程不知道这一点,因此如果有人试图在我们安装镜像时删除镜像,守护进程会感到困惑。锁定和操作必须在守护进程内完成。

当我们开始创建新的容器引擎时,我们需要的第一件事就是构建一个新的容器/存储库,它不需要守护进程来控制它。我们希望允许多个工具同时使用存储,而无需相互了解。

我们将使用文件系统锁定来控制对存储数据的访问。第一步是分离出 Docker 项目下的容器/存储,称为 graphdriver。这些存储驱动程序实现了不同的写时复制(COW)存储驱动程序,包括overlay、devicemapper、btrfs、xfs、vfs、aufs……如果你想在go项目中使用该库,那么你只需实现一个存储即可。

[请注意,容器/存储库与容器存储接口CSI)无关。容器/存储是将容器镜像存储在COW文件系统上,而CSI则用于容器写入的卷。例如,您可以使用 CSI 来存储 MariaDB 容器镜像使用的数据库,该数据库存储在容器/存储中。我希望这能消除任何困惑。

容器存储配置在 storage.conf 文件中定义。对于以 root 身份运行的容器引擎,storage.conf 文件存储在/etc/containers/storage.conf.如果您使用 Podman 等工具无根运行,则 storage.conf 文件存储在$HOME/.config/containers/storage.conf.

现在我们来看一下storage.conf。

driver


$ cat /etc/containers/storage.conf
# This file is is the configuration file for all tools
# that use the containers/storage library.
# See man 5 containers-storage.conf for more information
# The "container storage" table contains all of the server options.
[storage]
# Default Storage Driver
driver = "overlay"


驱动领域至关重要。在容器/存储中,我们默认使用overlay驱动程序。在 Docker 世界中,有两个 Overlay 驱动程序,overlay 和 Overlay2,现在大多数用户使用 Overlay2 驱动程序,所以我们只使用其中一个,并将其称为 Overlay。如果您不小心在配置容器中使用了overlay2,存储足够智能,可以将其别名为overlay。

graphroot


# Temporary storage location
runroot = "/var/run/containers/storage"
# Primary Read/Write location of container storage
graphroot = "/var/lib/containers/storage"

graphroot定义了实际镜像的存储位置。我们建议您在此位置设置大量空间,因为人们往往会随着时间的推移存储大量镜像。设置存储不需要特殊工具,您应该使用标准 Linux 命令以最适合您需求的任何方式设置存储,但我们建议您在 /var/lib/containers 上挂载大型设备。

storage.options

[storage.options]
# Storage options to be passed to underlying storage drivers

每个图形驱动程序有很多存储选项。其中一些允许您使用容器存储做一些有趣的事情,我将在下面讨论其中的一些。

additionalimagestores


# AdditionalImageStores is used to pass paths to additional Read/Only image stores
# Must be comma separated list.
additionalimagestores = [
]


additionalimagestores是一项很酷的功能,它允许您设置附加的只读镜像存储。例如,您可以设置包含许多覆盖容器镜像像的 NFS 共享,并通过 NFS 与所有容器引擎共享它们。然后,他们可以使用 NFS 存储上的镜像并启动容器,而不是要求每个运行容器引擎的节点拉取巨大的镜像。

size


# Size is used to set a maximum size of the container image.  Only supported by
# certain container storage drivers.
size = ""


大小控制容器镜像的大小,如果您运行的系统中有大量用户将拉取镜像,您可能需要设置配额以确保没有用户能够拉取巨大的镜像。例如,OpenShift.com使用此功能来控制其用户,尤其是在使用OpenShift Online时。

mounting


# Path to an helper program to use for mounting the file system instead of mounting it
# directly.
# mount_program = "/usr/bin/fuse-overlayfs"
# mountopt specifies comma separated list of extra mount options
mountopt = "nodev"


该标志允许您将特殊的安装选项传递到驱动程序中。例如,设置该nodev字段可防止用户使用容器镜像中显示的设备节点。容器引擎在安装于 的 tmpfs 上提供设备/dev,因此没有理由将设备嵌入到镜像中,特别是当它们可用于规避安全性时。

Remap-UIDs/GIDs


# Remap-UIDs/GIDs is the mapping from UIDs/GIDs as they should appear inside of
# a container, to UIDs/GIDs as they should appear outside of the container, and
# the length of the range of UIDs/GIDs. Additional mapped sets can be listed
# and will be heeded by libraries, but there are limits to the number of
# mappings which the kernel will allow when you later attempt to run a
# container.
#
# remap-uids = 065536
# remap-gids = 065536


重新映射 uids 和 gids 标志告诉容器/存储以重新映射的格式存储镜像,供指定用户命名空间内的用户使用。如果您设置remap-uidsto ,065536这会告诉容器存储在存储镜像时重新映射UID=0to100,000, UID=1、to等(直到 uid )拥有的文件。现在,如果容器引擎在映射内运行容器,它将使用与用户而不是 root 关联的 uid 更安全地运行。100,001``UID=2``100,0002``65536


# Remap-User/Group is a name which can be used to look up one or more UID/GID
# ranges in the /etc/subuid or /etc/subgid file. Mappings are set up starting
# with an in-container ID of 0 and the a host-level ID taken from the lowest
# range that matches the specified name, and using the length of that range.
# Additional ranges are then assigned, using the ranges which specify the
# lowest host-level IDs first, to the lowest not-yet-mapped container-level ID,
# until all of the entries have been used for maps.
#
# remap-user = "storage"
# remap-group = "storage"
[storage.options.thinpool]
# Storage Options for thinpool


Others

其余选项用于使用 devicemapper 等驱动程序以及其他一些选项创建 Thinpool。您可以参考/etc/containers/storage.conf磁盘上的文件以获取说明,也可以参考 storage.conf(5) 手册页以获取更多信息。

使用容器存储

容器引擎和 Podman、Buildah、CRI-O、Skopeo 等工具同时共享容器存储。他们都可以看到彼此的镜像,并且可以基于文件锁定彼此结合使用或完全单独使用。这意味着 podman 可以安装和检查容器。虽然它们共享实际存储,但它们不一定共享容器信息。有些工具具有不同的容器用例,并且不会显示其他工具的容器。例如,buildah 只是为了构建容器镜像的过程而创建构建容器,因为这些不需要 podman 容器的所有内容,所以它有一个单独的数据库。机器人工具可以删除彼此的容器镜像,但它们会单独处理它们。


# podman create -ti --name fedora-ctr fedora sh
ed4b68304e9fbbbc527593c28c917535e1d67d7d5c3f25edc568b71275ab69fc
sh-4.4# podman mount fedora-ctr
/var/lib/containers/storage/overlay/b16991596db22b90b78ef10276e2ae73a1c2ca9605014cad95aac00bff6608bc/merged
# ls /var/lib/containers/storage/overlay/b16991596db22b90b78ef10276e2ae73a1c2ca9605014cad95aac00bff6608bc/merged
binbootdevetchomeliblib64lost+foundmediamntoptprocrootrunsbinsrvsystmpusrvar

虽然 buildah 和 CRI-O 可以使用相同的 Fedora 镜像

您甚至可以使用 Skopeo 在启动时预加载容器/存储,以使容器/镜像可供任何容器工具技术使用。请记住,没有容器守护程序控制此访问,只有标准文件系统工具。

审核编辑:黄飞

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

    关注

    19

    文章

    820

    浏览量

    47915
  • 容器
    +关注

    关注

    0

    文章

    492

    浏览量

    22029

原文标题:Podman中如何使用容器存储库和相关工具

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

收藏 人收藏

    评论

    相关推荐

    SQL存储过程在.NET数据的应用

    。  图3五.创建简单存储过程的数据应用程序: 下面我们就运用上述的不带参数的存储过程来一个数据应用程序,其中还用到了ADO.
    发表于 12-31 16:54

    如何在Docker创建容器

    是 Docker 映像(image)文件的最大存储,Docker Hub的映像文件是由其他开发者自定义并上传的。 3.在搜索结果清单中选中您需要的项目,然后点击“下载”。下载的映像文件将被添加到“映像
    发表于 01-03 15:58

    超级电容器的原理及应用

    非常大。根据超级电容器原理,其在运用过程中并没有出现化学反应,仅仅是在物理性质上的变化,因而超级电容器的稳定性更加可靠。 目前,超级电容器凭借强大的储存容量及
    发表于 07-21 15:56

    超级电容器的原理及应用

    非常大。根据超级电容器原理,其在运用过程中并没有出现化学反应,仅仅是在物理性质上的变化,因而超级电容器的稳定性更加可靠。目前,超级电容器凭借强大的储存容量及
    发表于 04-29 15:04

    在汇编程序灵活运用TSRs的程序

    在汇编程序灵活运用TSRs的程序
    发表于 02-24 14:43 2次下载

    数据存储过程和触发器有什么作用?如何创建和应用?

    很多管理任务,利用一些常用的系统存储过程可以很方便的查看、操作数据对象。系统存储过程的命名通常以”sp_”作为前缀,并且存储于Master数据
    发表于 09-26 15:15 3次下载
    数据<b class='flag-5'>库</b><b class='flag-5'>中</b><b class='flag-5'>存储</b>过程和触发器有什么作用?如何创建和应用?

    判断Linux文件编译时是否运用-g选项的方法

    判断Linux文件编译时是否运用-g选项的方法
    的头像 发表于 06-22 08:40 3387次阅读
    判断Linux<b class='flag-5'>库</b>文件编译时是否<b class='flag-5'>运用</b>-g选项的方法

    2021年最热门的云原生存储解决方案之一:容器原生存储

    能够在容器内运行。结合诸如StatefulSets之类的K8s设计,它提供了可靠性和稳定性,可以在生产环境运行任务关键型工作负载。 与容器运行时一起,容器原生
    的头像 发表于 01-06 17:48 2700次阅读
    2021年最热门的云原生<b class='flag-5'>存储</b>解决方案之一:<b class='flag-5'>容器</b>原生<b class='flag-5'>存储</b>

    Podman for macOS macOS平台的Podman前端

    ./oschina_soft/podman-macos.zip
    发表于 06-23 11:13 0次下载
    <b class='flag-5'>Podman</b> for macOS macOS平台的<b class='flag-5'>Podman</b>前端

    STM32Cbue LL巧妙运用“静态内联”

    STM32的标准外设、HAL、LL软件,都有很多巧妙之处值得大家借鉴。 今天讲讲STM32Cbue LL巧妙运用“静态内联”使代
    发表于 08-14 14:30 1124次阅读

    在Rocky8安装并使用podman

    Podman是redhat发行的容器管理工具,类似于docker,但是没有守护进程。它不仅可以管理OCI容器,还可以管理pod, 这也是和docker的最大差别吧.
    的头像 发表于 10-10 09:32 2080次阅读

    如何安装podman并创建podman容器

    Nano 现在已安装在你的自定义容器。还可以交互式的运行容器
    的头像 发表于 11-10 09:17 3053次阅读

    组织容器网络的原理及方案

    Podman 容器管理器的一个很好的特性是关注于 rootless 容器。但是,你可能注意到,本文使用了很多 sudo 命令。说明,没有 root 权限无法配置网络。
    发表于 12-31 16:01 299次阅读

    C++之STL容器

    前面跟大家介绍过STL,STL主要是由6大部分组成,其中第一个提到的就是容器容器在介绍STL中小哥有简单的跟大家介绍过,今天稍微再详细介绍一下
    的头像 发表于 02-21 10:55 1147次阅读
    C++之STL<b class='flag-5'>库</b><b class='flag-5'>中</b>的<b class='flag-5'>容器</b>

    超级电容器的应用

    容器能够集成到消费电子产品,IT设备和通信体系,以保护存储器内容。相关运用程序是内部备用电源。超级电容器能够作为电池替换或短期备用电源。
    的头像 发表于 02-10 18:03 1875次阅读
    超级电<b class='flag-5'>容器</b>的应用