libblkid仅适用于root用户并在以root身份运行后才能使用

3

这是我见过的最奇怪的事情(实际上,它有一个很好的解释)。

我创建了一段C代码来列出分区及其类型:

char *get_luks_partition(void) {
    blkid_dev dev;
    blkid_cache cache;
    blkid_dev_iterate iter;
    const char *devname = NULL;
    char *ret = NULL;
    const char *type = NULL;

    if (blkid_get_cache(&cache, NULL))
        return NULL;
    blkid_probe_all(cache);

    iter = blkid_dev_iterate_begin(cache);

    while (!blkid_dev_next(iter, &dev)) {
        devname = blkid_dev_devname(dev);
        type = blkid_get_tag_value(cache, "TYPE", devname);

        if (type)
            printf("dev: %s type: %s\n", devname, type);

        if (type && !strcmp(type, "crypto_LUKS")) {
            ret = (char *) devname;
            break;
        }
    }

    blkid_dev_iterate_end(iter);

    return ret;
}

当我以普通用户身份运行时,它不显示任何设备/分区和类型。 因此,我尝试以root身份运行,最终看到了设备、分区和类型。 当我返回到用户时,如果再次运行,我可以看到与root相同的输出。 请看以下顺序:

$ ./main 
dev: /dev/sr0 type: udf

$ sudo ./main 
dev: /dev/vda1 type: vfat
dev: /dev/vda2 type: xfs
dev: /dev/vda3 type: crypto_LUKS

$ ./main 
dev: /dev/vda1 type: vfat
dev: /dev/vda2 type: xfs
dev: /dev/vda3 type: crypto_LUKS

有人知道发生了什么吗?

1个回答

3
从blkid(8)手册页中: libblkid库用于识别块设备(磁盘)的内容(例如文件系统类型),以及提取其他信息,如文件系统标签/卷名、唯一标识符/序列号。常见的用途是允许将LABEL=和UUID=标记用于配置文件中,而不是硬编码特定的块设备名称。
请注意,blkid直接从设备上读取信息,对于非root用户,它会返回缓存的未经验证信息。
从LIBBLKID(3)手册页中:
该库的高级部分在缓存文件中保存有关块设备的信息,并在返回给用户之前进行验证是否仍然有效(如果用户对原始块设备具有读取权限,否则不)。缓存文件还允许非特权用户(通常是任何非root用户或不属于“disk”组的用户)通过标签/ID查找设备。缓存文件的标准位置可以通过环境变量BLKID_FILE覆盖。
因此,在以root身份运行后,信息将被缓存。之后以非root身份再次运行时,将检索该信息。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接