新容器引擎崛起,Docker地位不保

云计算
Podman 是一种无守护进程的容器引擎,旨在使用开放容器倡议 (OCI) 容器和容器映像轻松查找、运行、构建、共享和部署应用程序。

概念

Podman 是一种无守护进程的容器引擎,旨在使用开放容器倡议 (OCI) 容器和容器映像轻松查找、运行、构建、共享和部署应用程序。Podman 提供了与 Docker 开源引擎相同的命令行界面,大多数用户可以简单地将 Docker 别名为 Podman(别名 docker=podman),没有任何问题。与其他常见的容器引擎(Docker、CRI-O、containerd)类似,Podman 依赖于符合 OCI 的容器运行时(runc、crun、runv 等)与操作系统交互并创建正在运行的容器。这使得 Podman 创建的运行容器与任何其他常见容器引擎创建的容器几乎没有区别。

起源与发展

Podman 的起源可以追溯到 Red Hat 团队对 Docker 的重新思考。他们发现,虽然 Docker 已经成为了容器技术的代名词,但是它使用守护进程的运行方式、需要特权用户启动容器以及潜在的安全性问题都限制了其使用范围。因此,他们决定开发一种新的容器引擎,旨在解决这些问题。

Podman 的发展经历了多个阶段。最初,Podman 是作为 CRI-O 项目的一部分而开发的,旨在直接访问 OCI 的实现(如 runC),流程比 Docker 要短。Podman 是一个开源的容器运行时项目,可在大多数 Linux 平台上使用。随着时间的推移,Podman 逐渐成为了 Red Hat 8 和 CentOS 8 中的默认容器引擎,并且得到了其他发行版的欢迎。

目前,Podman 已经成为了OCI(Open Container Initiative)的标准容器引擎之一。它不仅与 Docker 兼容,还具有一些 Docker 不具备的优点,如无守护进程的运行方式、更好的安全性和多租户支持。此外,Podman 还允许用户在没有完全 root 权限的情况下运行容器。

在现状方面,Podman 已经得到了广泛的应用。许多企业和组织都选择使用 Podman 来代替 Docker,以获得更高的安全性、更好的性能和更简单的管理。此外,由于 Podman 的开源性质和良好的兼容性,它也得到了其他发行版的欢迎和支持。

与Docker相比

Podman 和 Docker 都是容器引擎,但它们之间存在一些明显的区别。

运行方式:

Docker 需要在系统上运行一个守护进程(docker daemon),而 podman 不需要。

Docker CLI 命令通过 API 与 Docker Engine(引擎)交互告诉它创建一个 container,然后 Docker Engine 才会调用 OCI container runtime(runc)来启动一个 container。这意味着 container 的 process(进程)不会是 Docker CLI 的 child process(子进程),而是 Docker Engine 的 child process。

Podman 是直接给 OCI container runtime(runc)进行交互来创建 container 的,所以 container process 直接是 podman 的 child process。

Podman 可以在 rootless 模式下运行。

镜像存储库:

Podman 使用标准的 Linux 文件系统来存储镜像,而 Docker 使用自己的存储库。这意味着 Podman 可以直接访问本地镜像,而 Docker 需要通过 Docker 存储库来访问镜像。

镜像格式:

Podman 使用 OCI(Open Container Initiative)镜像格式,而 Docker 使用自己的镜像格式。这意味着 Podman 可以直接使用 OCI 镜像,而 Docker 需要将 OCI 镜像转换为 Docker 镜像才能使用。

进程管理:

Podman 使用标准的 Linux 进程管理工具(例如 systemd)来管理容器进程,而 Docker 使用自己的进程管理方式。

对未来的影响

Podman的崛起对Docker的影响可能会有以下几个方面:

更安全:

如前所述,Podman不需要在系统上运行守护进程,也不需要以root用户身份运行,这使得Podman比Docker更加安全。这种安全性的提高可能会使得更多的企业和组织选择使用Podman代替Docker。

更灵活:

Podman可以在没有root权限的情况下运行,这使得它在某些场景下比Docker更加灵活。例如,在受限的环境下,如容器化的应用程序或开发环境中,Podman可能会是一个更好的选择。

更高效:

Podman直接与OCI container runtime(如runc)交互,这使得它比Docker更加高效。Docker的容器创建命令需要通过API与Docker Engine(引擎)交互,这可能会增加一些额外的开销。

至于未来Podman取代Docker的可能性,这取决于多种因素。首先,虽然Podman具有一些优点,但Docker已经成为了容器技术的代名词,具有广泛的应用和社区支持。其次,Docker的生态系统非常成熟,包括大量的工具、插件和镜像,这些可能会阻碍Podman的普及。最后,Docker在容器编排和集群管理方面也有一些优势。

综上所述,Podman可能会在某些方面逐渐取代Docker,特别是在安全性和灵活性方面。然而,要完全取代Docker还需要时间和社区的支持。在未来,更有可能的是Podman和Docker共存,根据不同的需求和场景选择合适的容器引擎。

责任编辑:华轩 来源: 运维book思议
相关推荐

2024-08-20 14:52:12

2018-09-13 08:19:50

Python Java 编程语言

2016-02-25 10:09:15

MapReduceHadoopHDFS

2009-09-27 10:15:59

Adobe Flash

2017-01-13 08:09:07

手机

2024-04-11 10:00:00

特斯拉

2020-09-22 15:16:49

Python编程语言Julia

2019-12-12 10:58:37

Docker容器引擎

2012-08-03 15:02:05

Android 4.0

2014-12-12 11:29:02

DockerLinux

2017-02-22 14:30:30

IT存储工程师公有云

2017-09-07 09:40:00

2023-11-09 23:51:32

2014-11-06 10:18:10

googleDocker

2016-08-02 11:41:44

云计算

2019-11-15 22:36:27

容器Docker Kubernetes

2019-04-10 18:56:40

5G边缘计算云计算

2014-12-03 10:13:01

Docker容器技术Rocket

2012-12-03 09:22:41

KVM服务器虚拟化

2018-10-11 10:34:06

点赞
收藏

51CTO技术栈公众号