无需sudo使用Podman在Linux上运行容器

系统 Linux
本文演示了如何配置你的 Linux 系统,使普通用户可以在不使用 sudo 的情况下(“无根”)运行 Podman。


配置你的系统使用无根容器。


容器是现代计算的一个重要组成部分,随着围绕容器的基础设施的发展,新的和更好的工具开始浮出水面。过去,你只需用 ​​LXC​​​ 就可以运行容器,然而随着 Docker 得到了普及,它开始变得越来越复杂。最终,我们在 ​​Podman​​ 得到了我们所期望的容器管理系统:一个无守护进程的容器引擎,它使容器和吊舱易于构建、运行和管理。

容器直接与 Linux 内核能力(如控制组和命名空间)交互,它们在这些命名空间中产生大量的新进程。简而言之,运行一个容器实际上就是在 Linux 系统内部运行一个 Linux 系统。从操作系统的角度来看,它看起来非常像一种管理和特权活动。普通用户通常不能像容器那样自由支配系统资源,所以默认情况下,运行 Podman 需要 root 或 ​​sudo​​​ 权限。然而,这只是默认设置,而且这绝不是唯一可用的设置。本文演示了如何配置你的 Linux 系统,使普通用户可以在不使用 ​​sudo​​ 的情况下(“无根rootless”)运行 Podman。

命名空间的用户 ID

​内核命名空间​​ 本质上是一种虚构的结构,可帮助 Linux 跟踪哪些进程属于同一类。这是 Linux 中的“队列护栏”。一个队列中的进程与另一个队列中的进程之间实际上没有区别,但可以将它们用“警戒线”彼此隔离。要声明一组进程为“容器”,而另一组进程为你的操作系统,将它们分开是关键。

Linux 通过用户 ID(UID)和组 ID(GID)来跟踪哪个用户或组拥有的进程。通常情况下,一个用户可以访问一千个左右的从属 UID,以分配给命名空间的子进程。由于 Podman 运行的是分配给启动容器的用户的整个从属操作系统,因此你需要的不仅仅是默认分配的从属 UID 和从属 GID。

你可以用 ​​usermod​​​ 命令授予一个用户更多的从属 UID 和从属 GID。例如,要授予用户 ​​tux​​ 更多的从属 UID 和从属 GID,选择一个还没分配用户的适当的高 UID(如 200000),然后将其增加几千:

$ sudo usermod \
--add-subuids 200000-265536 \
--add-subgids 200000-265536 \
tux


命名空间访问

对命名空间数量也有限制。这通常被设置得很高。你可以用 ​​systctl​​,即内核参数工具来验证用户的命名空间分配:

$ sysctl --all --pattern user_namespaces
user.max_user_namespaces = 28633


这是很充足的命名空间,而且可能是你的发行版默认设置的。如果你的发行版没有这个属性或者设置得很低,那么你可以在文件 ​​/etc/sysctl.d/userns.conf​​ 中输入这样的文本来创建它:

user.max_user_namespaces=28633

加载该设置:

$ sudo sysctl -p /etc/sysctl.d/userns.conf

在没有 root 权限的情况下运行一个容器

当你设置好你的配置,重启你的计算机,以确保你的用户和内核参数的变化被加载和激活。

重启后,试着运行一个容器镜像:

$ podman run -it busybox echo "hello"
hello


容器像命令一样

如果你是第一次接触容器,可能会觉得很神秘,但实际上,它们与你现有的 Linux 系统没有什么不同。它们实际上是在你的系统上运行的进程,没有仿真环境或虚拟机的成本和障碍。容器和你的操作系统之间的区别只是内核命名空间,所以它们实际上只是带有不同标签的本地进程。Podman 使这一点比以往更加明显,当你将 Podman 配置为无根命令,容器感觉更像命令而不是虚拟环境。Podman 使容器和吊舱变得简单,所以请试一试。

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

2022-09-22 16:21:43

开源GUI 应用

2019-03-22 09:20:45

Linux命令sudo

2018-10-26 16:20:27

PodmanrootLinux

2021-02-17 09:16:58

PodmanLinuxDocker

2021-05-17 12:54:04

AnsiblePodman开源

2011-01-13 09:44:19

Linuxsudo技巧

2022-05-25 16:38:42

sudoLinuxroot 账户

2018-01-29 11:40:44

LinuxAndroidTermux

2021-07-31 12:58:53

PodmanLinux虚拟机

2010-10-12 13:40:54

Linuxsudo

2022-06-30 13:54:16

BottlesLinuxWindows

2017-09-18 10:05:15

WindowsLinux容器

2017-09-19 15:40:23

Linuxsudo命令密码

2011-03-25 11:21:36

NagiosLinux

2021-07-25 10:34:17

FedoraPodmanLinux

2022-06-23 09:55:56

WineZGUILinux 桌面Windows 应用

2011-03-22 10:06:27

LinuxZFS

2019-12-05 10:30:17

LinuxMultitail

2020-06-11 14:33:10

MacBookLinux软件

2018-07-10 14:46:04

LinuxShellsudo
点赞
收藏

51CTO技术栈公众号