我有一个 NAS,其中包含我家每个成员的目录。
我的用户名,是每个成员组的成员。所以我可以访问所有用户的文件夹。
我希望,当我在用户目录中放置文件时,该文件从父目录中获取所有权。或获取特定权限。
我妻子的目录是“zoe_folder”,拥有 zoe:zoe 和权限 rwxrwx---。
当我以 root 身份运行touch file.txt
我妻子目录(或子目录)中的命令时,file.txt 拥有 root:root 所有权和权限 rw-r--r--。我想要所有权 zoe:zoe(或作为解决方法权限 rw-rw-rw-)。
当然,无需运行任何命令chmod
,chown
. 它是 NAS,客户端 PC 是 Windows。我无法每次使用控制台登录 NAS 并更改权限。
有任何想法吗?
我认为您正在寻找的是:
在每个用户的目录上使用一个setgid,这样该目录中的每个新文件都将与该目录具有相同的组;和
将您的系统设置
umask
为 0002,因为它看起来是 0022。从默认权限umask
中删除现有权限,默认权限是 0777 用于目录,0666 用于文件。使用新设置,文件的默认权限将更改:从 0644 到 0664,对于目录:从 0755 到 0775。我对您提供的详细信息的理解是它将适用于您的系统。要将setgid放在所有子目录上,请使用以下
find
命令,但 请确保您的起始目录是用户目录之上的那个,以便简单的ls
将它们全部列出,因为使用错误的起始目录会导致扭转所有已经完成的事情有点痛苦:find ./ -type d -mindepth 1 -maxdepth 1 -exec chmod --preserve-root g+s '{}' \;
给定的选项执行以下操作:
-type d
返回文件类型“目录”的所有内容;-mindepth 1
防止列出起始目录,使其权限不会改变;-maxdepth 1
列出第一级子目录,但不深入到自己的子目录;-exec
对通过测试的每个项目执行以下命令,这就是 '{}' 的含义;和--preserve-root
是 chmod 中的一种保护,以防止权限更改意外应用于根目录(可能还有整个文件系统)。如果您不确定什么会受到影响,只需运行
find
不带参数的命令-exec
,如下所示:find ./ -type d -mindepth 1 -maxdepth 1
,它将为您提供它将传递给您与-exec
参数一起使用的任何命令的每个文件的列表。可能重复
通过一个小的搜索,我发现这个问题 可能已经(部分)在这里得到了回答:
如何为目录中的所有文件夹/文件设置默认文件权限?
接受的答案是关于如何在https://www.linuxquestions.org/questions/linux-desktop-74/applying-default-permissions-for-newly-中为目录设置默认权限的分步教程created-files-within-a-specific-folder-605129/
请确认是否是这种情况。