UID / GID 自动映射

    简单来说,就是同样名称但不同 UID / GID 的用户创建的文件会在元数据里自动映射为同一个内部 UID / GID,在挂载到主机时再转换为与之匹配的本地 UID / GID。

    在 Ubuntu 系统的主机 X 上创建 UID 为 的用户 juicefs,挂载 JuiceFS 到 /jfs,然后在其中创建一个空目录 juicefs@ubuntu

    1. [centos]# useradd -m -G wheel -u 2002 juicefs
    2. uid=2002(juicefs) gid=2002(juicefs) groups=2002(juicefs),10(wheel)
    3. [centos]# su juicefs
    4. [centos]$ mkdir /jfs/juicefs@centos

    通过 ls -l 列取目录所有者,可以看到在两个主机下目录的所有者均显示为 juicefs

    1. [centos]$ ls -l /jfs
    2. drwxrwxr-x. 3 juicefs juicefs 8192 Aug 22 12:35 juicefs@ubuntu

    通过 查看目录所有者的 UID 和 GID。

    而 Ubuntu 下 UID 1001 用户创建的目录 juicefs@ubuntu 在 CentOS 下映射为 UID 2002

    1. [centos]$ ls -n /jfs
    2. drwxr-xr-x. 2 2002 2002 4096 Aug 22 13:02 juicefs@centos

    JuiceFS 客户端会在挂载文件系统时,会建立系统里所有用户名及组名到内部 ID 的哈希映射,将匹配成功的内部 UID / GID 自动转换为对应名称的实际 UID / GID。如果匹配失败,则不进行转换。

    JuiceFS 默认将系统用户名映射为保留区段的内部 ID,建议用户避免使用 10000 以上的 UID,以降低产生冲突的概率。如需关闭此功能,请通过屏幕右下方的对话框联系客户支持。