我正在编写一个 Fuse 文件系统。
到目前为止一切正常,没有遇到无法解决的问题(性能除外)。
但是,我阅读了以下文章:
http://linuxcommand.org/lts0070.php
http://www.perlfect.com/articles/chmod.shtml
http://mason.gmu.edu/~montecin/UNIXpermiss.htm
http://www.linux.com/learn/tutorials/309527-understanding-linux-file-permissions
http://www.tutorialspoint.com/unix/unix-file-permission.htm
https://kb.iu。教育/d/abdb
我有以下问题:
给定一个通用的 unix-permission-string -
我理解字符串(在第一个字符之后)被分成 3 个(rwx)组
owner
owner_group
all/world/anyone
但是,其中一篇文章明确指出,1 个用户可以在 N 个组中。
那么为什么所有者组(而不是组)在这里使用单数?如果我(文件创建者和所有者)在几个组中,那么所有者组到底是什么?
假设我是 A 组、B 组和 C 组的成员。
现在我在某处创建一个文件。
由于表达式 owner_group 是单数而不是复数,所以 owner_group 权限应用到哪个组?
A XOR B XOR C,或者全部,或者一个都不?
如果它仅适用于一个(如单数暗示的那样),如何确定将权利分配给哪个组?
我有一种明显的感觉,我在这里并不真正理解某些东西,或者我误解了“所有者组”一词的含义。
foo
拥有该文件,而用户的其中一个组是foo
),则相应的组权限适用于该用户(除非被所有者权限覆盖)。所有者组是文件所有权的一部分。考虑:
这表明该文件的所有权属于 user
root
和 groupcrontab
。这取决于您创建该文件时您的主要组是什么。
groups
主要组是运行命令时列出的第一个组。通常,这由您的 GID 决定。newgrp
但是,您可以使用该命令临时将其他组之一设置为主要组。例如:所有者组是文件的属性,而不是用户。
小关:第三场是别人,不是全部。其他包括除文件所有者和文件所有者组成员之外的所有人。当使用符号模式时,区别开始发挥作用
chmod
:chmod a-x
带走所有人的执行权限chmod o-x
带走其他人的执行权限,同时保留所有者和所有者组的执行权限不变。最后,关于用户私人群组的说明。UPG 在桌面系统上相当普遍,但不要认为它们在其他地方是理所当然的。如果启用了 UPG,则用户的主要组和用户名可能具有相同的数字 ID 和名称,并且每个用户都有一个唯一的组。就这些。