我目前正在重建 Linux 系统,迁移到新的发行版(Ubuntu 24.04)。
我有一个磁盘,里面有几 TB 的用户数据,我想保留这些数据。该磁盘包含一个带有只读快照的 btrfs 文件系统,这限制了我调整磁盘内容的选项(我无法轻松更改只读快照)。
现在,新的 Linux 发行版默认带有一些组,这些组的 ID 从 1000 开始,并且对系统具有权限。然而,这些组与我在旧安装中使用的组 ID 相同,并且对 btrfs 文件系统具有权限。由于只读快照,我无法轻松更新用户数据上的组 ID。
有人向我指出了 ID 映射的坐骑,但没有关于如何使用它们的有用说明。
我是否可以将文件系统映射为文件系统 gid 1000 对应于系统 gid 1024?我该如何在 /etc/fstab 中输入该内容,以便在启动时挂载文件系统?
Ubuntu 24.04 足够新,可以完全支持 ID 映射挂载,包括标准挂载工具。
对于
mount
,这是通过X-mount.idmap=
选项指定的,后跟至少一个映射。多个映射以空格分隔。映射采用以下形式,其中:
[(u|g|b):]
mount_id
:
local_id
:
range
u
表示用户 ID 的映射,g
表示组 ID 的映射,b
或者无前缀表示用户和组 ID 的映射。mount_id
是挂载文件系统上出现的第一个 IDlocal_id
是本地系统上的 ID,对应于mount_id
range
是要映射的连续 ID 的数量(最高为mount_id
+range
- 1 和local_id
+range
- 1)一旦使用 idmapping,已挂载文件系统上任何未映射的 ID 将分别转换为
nobody
(uid 65534) 和nogroup
(gid 65534)。当在命令行上与多个选项一起指定此选项时,必须用引号引起来整个选项块,以便尽管有空格,它仍将被视为一个参数。
用于挂载文件系统的命令行,其中 uid 与本地系统相同,但是 gid 相差 24(本地 gid 1024 对应磁盘上的 1000),最大 uid/gid 为 65534,因此(其他挂载选项可能有所不同):
该
/etc/fstab
条目看起来类似,只是选项中的空格字符需要转义 - 就像在 shell 上一样,空格字符/etc/fstab
被视为分隔符。根据手册页,挂载路径中的空格字符被转义为\040
(八进制)。虽然没有明确提到,但它也适用于选项。因此条目etc/fstab
将是: